这篇文章主要介绍了Vue如何实现滑动验证功能,具有一定借鉴价值,感兴趣的朋友可以参考下,希望大家阅读完这篇文章之后大有收获,下面让小编带着大家一起了解一下。
用Vue实现滑动验证码,鼠标点击滑动验证,验证成功之后会显示验证通过。
程序分析
鼠标的点击
2、滑块的拖动
3、未验证之前滑动条上显示的文字
4、滑块箭头指向Vue函数
5、判断是否拖动完毕
6、拖动完毕时改变背景色并显示验证成功
效果图演示
原始状态
点击之后拖动
拖动完毕
有没有感觉很奇妙的呢???
在欣赏代码之前准备工作要做好的!!!
**特别注意:**相关架包的引入(三个架包)
<script src="js/vue.js"></script><script src="https://unpkg.com/element-ui/lib/index.js"></script><script src="js/jquery.js"></script>
代码演示
<!DOCTYPE html><html> <head> <meta charset="UTF-8"> <title></title> <script src="js/vue.js"></script> <script src="https://unpkg.com/element-ui/lib/index.js"></script> <script src="js/jquery.js"></script> <style> .big { border-radius:30px; position: relative; background-color: #75CDF9; width: 300px; height: 34px; margin-left: 30px; margin-top: 100px; line-height: 34px; text-align: center; } .hand { border-radius:30px; position: absolute; top: 0px; left: 0px; width: 40px; height: 32px; border: 1px solid #ccc; cursor: move; } .handler { background: #fff url("") no-repeat center; } .handlerFinish { background: #fff url("") no-repeat center; } .bg { border-radius:30px; background-color: #13CE66; height: 34px; width: 0px; } .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; } </style> </head> <body> <div id="app"> <div class="big" > <div class="bg"></div> <div class="text">{{confirmWords}}</div> <div @mousedown="mousedownFn($event)" class="hand handler"></div> </div> </div> </body> <script> 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() { $(".hand").removeClass('handler').addClass('handlerFinish'); this.confirmWords = '验证通过' $(".big").css({ 'color': '#fff' }); $(".big").css({ 'background-color': '#13CE66' }); $(".hand").css({ 'left': this.maxwidth }); $(".bg").css({ 'width': this.maxwidth }); $('body').unbind('mousemove'); $('body').unbind('mouseup'); this.confirmSuccess = true; } //判断是否成功 }, mounted() { $('body').on('mousemove', (e) => { //拖动使用箭头指向Vue函数 if(this.mouseMoveStata) { var width = e.clientX - this.beginClientX; if(width > 0 && width <= this.maxwidth) { $(".hand").css({ 'left': width }); $(".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) { $(".hand").css({ 'left': 0 }); $(".bg").css({ 'width': 0 }); } }) } }); </script></html>
感谢你能够认真阅读完这篇文章,希望小编分享的“Vue如何实现滑动验证功能”这篇文章对大家有帮助,同时也希望大家多多支持编程网,关注编程网行业资讯频道,更多相关知识等着你来学习!