首页 > 编程 > JavaScript > 正文

jQuery与vue实现拖动验证码功能

2019-11-19 14:27:27
字体:
来源:转载
供稿:网友

jquery的绿色拖动验证功能

在网上看到了一个这样的问题:那种像拖动滑块匹配图形的验证方式是怎么实现的?。

突然想到实现一个简单绿色拖动验证码的功能,在网上搜了下,有一个用jquery实现的该功能代码。

体验地址:http://yanshi.sucaihuo.com/jquery/8/897/demo/

其CSS代码:

#drag{   position: relative;  background-color: #e8e8e8;  width: 300px;  height: 34px;  line-height: 34px;  text-align: center;}#drag .handler{  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 .drag_bg{  background-color: #7ac23c;  height: 34px;  width: 0px;}#drag .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; }

HTML代码结构:

<center style="margin-top: 100px">  <div id="drag"></div></center>

JS调用方式:

$('#drag').drag();

JS实现代码:

(function($){  $.fn.drag = function(options){    var x, drag = this, isMove = false, defaults = {    };    var options = $.extend(defaults, options);    //添加背景,文字,滑块    var html = '<div class="drag_bg"></div>'+          '<div class="drag_text" onselectstart="return false;" unselectable="on">拖动滑块验证</div>'+          '<div class="handler handler_bg"></div>';    this.append(html);        var handler = drag.find('.handler');    var drag_bg = drag.find('.drag_bg');    var text = drag.find('.drag_text');    var maxWidth = drag.width() - handler.width(); //能滑动的最大间距        //鼠标按下时候的x轴的位置    handler.mousedown(function(e){      isMove = true;      x = e.pageX - parseInt(handler.css('left'), 10);    });        //鼠标指针在上下文移动时,移动距离大于0小于最大间距,滑块x轴位置等于鼠标移动距离    $(document).mousemove(function(e){      var _x = e.pageX - x;      if(isMove){        if(_x > 0 && _x <= maxWidth){          handler.css({'left': _x});          drag_bg.css({'width': _x});        }else if(_x > maxWidth){ //鼠标指针移动距离达到最大时清空事件          dragOk();        }      }    }).mouseup(function(e){      isMove = false;      var _x = e.pageX - x;      if(_x < maxWidth){ //鼠标松开时,如果没有达到最大距离位置,滑块就返回初始位置        handler.css({'left': 0});        drag_bg.css({'width': 0});      }    });        //清空事件    function dragOk(){      handler.removeClass('handler_bg').addClass('handler_ok_bg');      text.text('验证通过');      drag.css({'color': '#fff'});      handler.unbind('mousedown');      $(document).unbind('mousemove');      $(document).unbind('mouseup');    }  };})(jQuery);

VUE的绿色拖动验证功能

HTML结构:

<template>  <div id="drag">    <div class="drag_bg weui-btn_primary" :style="{width:curW+'px'}"></div>    <div class="drag_text" onselectstart="return false;" unselectable="on":class="[isDragOk ? 'whitecolor':'']">{{text}}</div>    <div class="handler" :style="{left:curW+'px'}" :class="[isDragOk ? 'handler_ok_bg':'handler_bg']"></div>  </div></template>

CSS代码:

<style scoped>#drag {  position: relative;  background-color: #e8e8e8;  width: 100%;  height: 36px;  line-height: 36px;  text-align: center;}#drag .drag_bg {  height: 36px;  width:0;}#drag .drag_text {  position: absolute;  top: 0px;  width: 100%;  -moz-user-select: none;  -webkit-user-select: none;  user-select: none;  -o-user-select: none;  -ms-user-select: none;}.drag_text.whitecolor{  color:#fff;}#drag .handler {  position: absolute;  top: 0px;  left: 0px;  width: 40px;  height: 34px;  border: 1px solid #ccc;  cursor: move;}.handler_bg {  background:#fff url("") no-repeat center}.handler_ok_bg {  background:#fff url("") no-repeat center}</style>

JS代码:

<script>export default{  name:'slider',  props:{      },  data(){    return{      curW:0,      isMove:false, //是否在运动      isDragOk:false, //是否拖动成功      maxWidth:0, //拖动的最大宽度      element:{},      text:'拖动滑块验证',      currentPos:{        x: 0,        y: 0      }    }  },  created(){      },  mounted () {    var self = this;    this.element = document.querySelector('.handler');    this.getMaxWidth();    window.addEventListener('resize',function(){self.getMaxWidth()});    window.addEventListener('orientationchange',function(){self.getMaxWidth()});             this.element.addEventListener('touchstart',self.touchstartFun,false);    document.querySelector('body').addEventListener('touchmove',self.touchmoveFun,false);    document.querySelector('body').addEventListener('touchend',self.touchendFun,false);        this.element.addEventListener('mousedown',self.touchstartFun,false);    document.querySelector('body').addEventListener('mousemove',self.touchmoveFun,false);    document.querySelector('body').addEventListener('mouseup',self.touchendFun,false);        (function drawAnimate() {      if( self.curW <= self.maxWidth){        window.requestAnimFrame(drawAnimate,1000/60);        self.curW = self.currentPos.x;      }else{        self.curW = self.currentPos.x = self.maxWidth;      }    })();  },  watch:{      },  methods:{    touchstartFun(e){      if(this.isDragOk){         e.preventDefault();         return;       }      this.isMove = true;      this.curW = this.currentPos.x = this.getCurrentPosition(e).x;    },    touchmoveFun(e){      if(this.isMove && this.curW > 0 && this.curW < this.maxWidth){        this.currentPos.x = this.getCurrentPosition(e).x;      }      else if(this.isMove && this.curW >= this.maxWidth){        this.curW = this.currentPos.x = this.maxWidth;        this.isDragOk = true;        this.text = "验证通过";      }    },    touchendFun(e){      this.isMove = false;      if(this.curW < this.maxWidth){        this.curW = this.currentPos.x = 0;      }    },        getCurrentPosition(event){      var xPos, yPos, rect;      rect = document.getElementById('drag').getBoundingClientRect();      //event = event.originalEvent;      //判断是touch,还是鼠标事件      if (event.type.indexOf('touch') !== -1) {        xPos = event.touches[0].clientX - rect.left;        yPos = event.touches[0].clientY - rect.top;      }            //鼠标事件      else {        xPos = event.clientX - rect.left;        yPos = event.clientY - rect.top;      }      return {        x: xPos,        y: yPos      }    },    getMaxWidth(){      this.maxWidth = document.querySelector("#drag").clientWidth - document.querySelector(".handler").scrollWidth;    }  }}</script>

页面引用方式:

<slider></slider>

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