失眠网,内容丰富有趣,生活中的好帮手!
失眠网 > css3 滑动验证 Vue 实现拖动滑块验证功能(只有css+js没有后台验证步骤)

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

时间:2023-10-24 01:22:40

相关推荐

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

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

效果图如下所示:

拖动前

拖动后

代码引用的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没有后台验证步骤),希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对脚本之家网站的支持!

如果觉得《css3 滑动验证 Vue 实现拖动滑块验证功能(只有css+js没有后台验证步骤)》对你有帮助,请点赞、收藏,并留下你的观点哦!

本内容不代表本网观点和政治立场,如有侵犯你的权益请联系我们处理。
网友评论
网友评论仅供其表达个人看法,并不表明网站立场。