首页 > 编程 > JavaScript > 正文

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

2019-11-19 13:10:22
字体:
来源:转载
供稿:网友

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

效果图如下所示:

拖动前

拖动后

代码引用的css与js都是线上的
将代码全部复制到一个html中可以直接打开,极其简单。
来分析一下代码
底色div上放了一个变色div再放一个提示字的div最后加一个滑块div
给滑块div绑定鼠标移动事件

<!DOCTYPE html><html> <head>  <meta charset="UTF-8">  <title></title>  <style scoped>   .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;   }  </style> </head> <body>  <div id="app">   <div class="drag" >    <div class="drag_bg"></div>    <div class="drag_text">{{confirmWords}}</div>    <div @mousedown="mousedownFn($event)" class="handler handler_bg"></div>   </div>  </div>  <script src="https://cdn.jsdelivr.net/npm/vue"></script>  <script src="https://unpkg.com/element-ui/lib/index.js"></script>  <script src="http://libs.baidu.com/jquery/2.1.4/jquery.min.js"></script>  <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() {      $(".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       });      }     })    }   });  </script> </body></html>

总结

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

发表评论 共有条评论
用户名: 密码:
验证码: 匿名发表