css3 滑动验证,Vue 实现拖动滑块验证功能(只有css+js没有后台验证步骤)

vue验证滑块功能,在生活中很多地方都可以见到,那么使用起来非常方便,基于vue如何实现滑块验证呢?下面通过代码给大家讲解。

效果图如下所示:

fdb045443c703fa722a0d300157a9c10.png

拖动前

26bb3995a4a0cdece23949c942d06833.png

拖动后

代码引用的css与js都是线上的

将代码全部复制到一个html中可以直接打开,极其简单。

来分析一下代码

底色div上放了一个变色div再放一个提示字的div最后加一个滑块div

给滑块div绑定鼠标移动事件

.drag {

border-radius:30px;

position: relative;

background-color: #75CDF9;

width: 300px;

height: 34px;

margin-left: 30px;

margin-top: 100px;

line-height: 34px;

text-align: center;

}

.handler {

border-radius:30px;

position: absolute;

top: 0px;

left: 0px;

width: 40px;

height: 32px;

border: 1px solid #ccc;

cursor: move;

}

.handler_bg {

background: #fff url("") no-repeat center;

}

.handler_ok_bg {

background: #fff url("") no-repeat center;

}

.drag_bg {

border-radius:30px;

background-color: #13CE66;

height: 34px;

width: 0px;

}

.drag_text {

position: absolute;

top: 0px;

width: 300px;

-moz-user-select: none;

-webkit-user-select: none;

user-select: none;

-o-user-select: none;

-ms-user-select: none;

}

{{confirmWords}}

var vm = new Vue({

el: "#app",

name: '',

components: {},

props: {},

data() {

return {

beginClientX: 0,

/*距离屏幕左端距离*/

mouseMoveStata: false,

/*触发拖动状态 判断*/

maxwidth: 258,

/*拖动最大宽度,依据滑块宽度算出来的*/

confirmWords: '拖动滑块验证',

/*滑块文字*/

confirmSuccess: false, /*验证成功判断*/

}

},

created() {},

watch: {

},

methods: {

mousedownFn: function(e) {

this.mouseMoveStata = true;

this.beginClientX = e.clientX;

}, //按下滑块函数

successFunction() {

$(".handler").removeClass('handler_bg').addClass('handler_ok_bg');

this.confirmWords = '验证通过'

$(".drag").css({

'color': '#fff'

});

$(".drag").css({

'background-color': '#13CE66'

});

$(".handler").css({

'left': this.maxwidth

});

$(".drag_bg").css({

'width': this.maxwidth

});

$('body').unbind('mousemove');

$('body').unbind('mouseup');

this.confirmSuccess = true;

} //验证成功函数

},

mounted() {

$('body').on('mousemove', (e) => {

//拖动,这里需要用箭头函数,不然this的指向不会是vue对象

if(this.mouseMoveStata) {

var width = e.clientX - this.beginClientX;

if(width > 0 && width <= this.maxwidth) {

$(".handler").css({

'left': width

});

$(".drag_bg").css({

'width': width

});

} else if(width > this.maxwidth) {

this.successFunction();

}

}

});

$('body').on('mouseup', (e) => {

//鼠标放开

this.mouseMoveStata = false;

var width = e.clientX - this.beginClientX;

if(width < this.maxwidth) {

$(".handler").css({

'left': 0

});

$(".drag_bg").css({

'width': 0

});

}

})

}

});

总结

以上所述是小编给大家介绍的Vue 实现拖动滑块验证功能(只有css+js没有后台验证步骤),希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对脚本之家网站的支持!

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值