欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页  >  IT编程

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

程序员文章站 2022-05-07 14:09:09
jquery的绿色拖动验证功能 在网上看到了一个这样的问题:那种像拖动滑块匹配图形的验证方式是怎么实现的?。 突然想到实现一个简单绿色拖动验证码的功能,在网上搜了下...

jquery的绿色拖动验证功能

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

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

体验地址:

其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>