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


Posted in jQuery onJanuary 30, 2018

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>
jQuery 相关文章推荐
jQuery简介_动力节点Java学院整理
Jul 04 jQuery
jQuery 循环遍历改变a标签的href(实例讲解)
Jul 12 jQuery
使用jQuery实现页面定时弹出广告效果
Aug 24 jQuery
jQuery实现可兼容IE6的滚动监听功能
Sep 20 jQuery
超好用的jQuery分页插件jpaginate用法示例【附源码下载】
Dec 06 jQuery
JS拖动选择table里的单元格完整实例【基于jQuery】
May 28 jQuery
jQuery设置下拉框显示与隐藏效果的方法分析
Sep 15 jQuery
javascript/jquery实现点击触发事件的方法分析
Nov 11 jQuery
jQuery操作选中select下拉框的值代码实例
Feb 07 jQuery
jQuery实现中奖播报功能(让文本滚动起来) 简单设置数值即可
Mar 20 jQuery
jQuery+css实现的点击图片放大缩小预览功能示例【图片预览 查看大图】
May 29 jQuery
jquery实现淡入淡出轮播图效果
Dec 13 jQuery
jquery动态添加以及遍历option并获取特定样式名称的option方法
Jan 29 #jQuery
jQuery代码优化方法总结
Jan 29 #jQuery
jquery写出PC端轮播图实例
Jan 26 #jQuery
jquery根据name取得select选中的值实例(超简单)
Jan 25 #jQuery
用jquery获取select标签中选中的option值及文本的示例
Jan 25 #jQuery
jQuery zTree搜索-关键字查询 递归无限层功能实现代码
Jan 25 #jQuery
使用Ajax和Jquery配合数据库实现下拉框的二级联动的示例
Jan 25 #jQuery
You might like
PHP 错误之引号中使用变量
2009/05/04 PHP
PHP session 会话处理函数
2016/06/06 PHP
PHP基于MySQLI函数封装的数据库连接工具类【定义与用法】
2017/08/11 PHP
JavaScript CSS修改学习第二章 样式
2010/02/19 Javascript
javascript cookies 设置、读取、删除实例代码
2010/04/12 Javascript
javascript定时保存表单数据的代码
2011/03/17 Javascript
最好用的Bootstrap fileinput.js文件上传组件
2016/12/12 Javascript
JavaScript中在光标处插入添加文本标签节点的详细方法
2017/03/22 Javascript
Angular2利用组件与指令实现图片轮播组件
2017/03/27 Javascript
微信小程序商城项目之商品属性分类(4)
2017/04/17 Javascript
Vue入门之animate过渡动画效果
2018/04/08 Javascript
浅谈微信页面入口文件被缓存解决方案
2018/09/29 Javascript
详解如何使用webpack打包多页jquery项目
2019/02/01 jQuery
微信小程序实现滚动加载更多的代码
2019/12/06 Javascript
微信小程序实现同时上传多张图片
2020/02/03 Javascript
vue+ElementUI 关闭对话框清空验证,清除form表单的操作
2020/08/06 Javascript
Vue 数据绑定的原理分析
2020/11/16 Javascript
详解vue 组件注册
2020/11/20 Vue.js
python list语法学习(带例子)
2013/11/01 Python
Python函数可变参数定义及其参数传递方式实例详解
2015/05/25 Python
Python 中 Virtualenv 和 pip 的简单用法详解
2017/08/18 Python
Python3 实现随机生成一组不重复数并按行写入文件
2018/04/09 Python
Python 实现Windows开机运行某软件的方法
2018/10/14 Python
Python中全局变量和局部变量的理解与区别
2021/02/07 Python
利用Python实现最小二乘法与梯度下降算法
2021/02/21 Python
CSS3实现复选框动画特效示例代码
2016/09/27 HTML / CSS
如何查找和删除数据库中的重复数据
2014/11/05 面试题
大学毕业登记表自我鉴定
2013/10/09 职场文书
经销商会议欢迎词
2014/01/11 职场文书
护理专业自荐信范文
2014/02/26 职场文书
2014年社区教育工作总结
2014/12/02 职场文书
2015年世界急救日宣传活动方案
2015/05/06 职场文书
孔子观后感
2015/06/08 职场文书
汤姆叔叔的小屋读书笔记
2015/06/30 职场文书
2015小学教育教学工作总结
2015/07/21 职场文书
Python3 如何开启自带http服务
2021/05/18 Python