日期: 2020-06-22 17:47:35
本文实例讲述了Vue插件之滑动验证码用法。分享给大家供大家参考,具体如下:
目前仅前端实现,支持移动端滑动事件。版本V1.1.2

github文档地址: https://github.com/monoplasty/vue-monoplasty-slide-verify
gitee镜像地址:https://gitee.com/monoplasty/vue-monoplasty-slide-verify
npm install --save vue-monoplasty-slide-verify
// main.js
import Vue from 'vue';
import SlideVerify from 'vue-monoplasty-slide-verify';
Vue.use(SlideVerify);
// template
<slide-verify
ref="slideblock"
@again="onAgain"
@fulfilled="onFulfilled"
@success="onSuccess"
@fail="onFail"
@refresh="onRefresh"
:accuracy="accuracy"
:slider-text="text"
></slide-verify>
<div>{{msg}}</div>
<button @click="handleClick">在父组件可以点我刷新哦</button>
// script
export default {
name: 'App',
data(){
return {
msg: '',
text: '向右滑',
// 精确度小,可允许的误差范围小;为1时,则表示滑块要与凹槽完全重叠,才能验证成功。默认值为5
accuracy: 1,
}
},
methods: {
onSuccess(){
console.log('验证通过');
this.msg = 'login success'
},
onFail(){
console.log('验证不通过');
this.msg = ''
},
onRefresh(){
console.log('点击了刷新小图标');
this.msg = ''
},
onFulfilled() {
console.log('刷新成功啦!');
},
onAgain() {
console.log('检测到非人为操作的哦!');
this.msg = 'try again';
// 刷新
this.$refs.slideblock.reset();
},
handleClick() {
// 父组件直接可以调用刷新方法
this.$refs.slideblock.reset();
},
}
}
imgs 参数不传是的warnaccuracy 精度设置判断滑块与凹槽位置的误差范围值,默认取值范围为 [1, 10]。若取值不为 -1,则会开启检测非人为操作。人为操作也有可能会触发哦!
判断依据是:滑块的一系列移动坐标的平均值和方差是否相等。若相等则人为是非人为操作。
若
accuracy为 -1,则表示关闭检测非人为操作,默认开启。开启之后,若检测到为非人为操作,则会触发again回调函数
imgs:imgs不传或者传空数组时,图片库默认使用第三方api提供的图片路径。可能加载缓慢;imgs传本地路径时,确保图片路径是否正确。建设传cdn上的图片地址。APP.vue上的写法。或在线查看demo地址<slide-verify ref="slideblock" ></slide-verify> // javascript 见使用方法 this.$refs.slideblock.reset();
| 参数 | 类型 | 默认值 | 描述 | 版本 |
|---|---|---|---|---|
| l | Number | 42 | 滑块的边长 | |
| r | Number | 10 | 滑块突出圆的半径 | |
| w | Number | 310 | canvas画布的宽 | |
| h | Number | 155 | canvas画布的高 | |
| sliderText | String | Slide filled right | 滑块底纹文字 | 1.0.5 |
| imgs | Array | [] | 背景图数组。可不传 | 1.1.0 |
| accuracy | Number | 5 | 滑动验证的误差范围 | 1.1.2 |
| show | Boolean | true | 是否显示刷新按钮 | 1.1.2 |
| 事件名 | 类型 | 描述 | 版本 |
|---|---|---|---|
| success | Function | 验证码匹配成功的回调 | |
| fail | Function | 验证码未匹配的回调 | |
| refresh | Function | 点击刷新按钮后的回调函数 | |
| again | Function | 检测到非人为操作滑动时触发的回调函数 | 1.1.2 |
| fulfilled | Function | 刷新成功之后的回调函数 | 1.1.2 |
目前仅是前端实现,如有什么问题欢迎issue或者留言。
希望本文所述对大家vue.js程序设计有所帮助。