vue实现一拉到底的滑动验证


Posted in Javascript onJuly 25, 2019

本文实例为大家分享了vue实现简单的一拉到底的滑动验证的具体代码,供大家参考,具体内容如下

直接上代码

<template>
 <div class="drag" ref="dragDiv">
  <div class="drag_bg"></div>
  <div class="drag_text">{{confirmWords}}</div>
  <div ref="moveDiv" @mousedown="mousedownFn($event)" :class="{'handler_ok_bg':confirmSuccess}" class="handler handler_bg" style="position: absolute;top: 0px;left: 0px;"></div>
 </div>
</template>

<script>
 export default {
  data(){
   return {
    beginClientX:0,   /*距离屏幕左端距离*/
    mouseMoveStata:false,  /*触发拖动状态 判断*/
    maxwidth:'',    /*拖动最大宽度,依据滑块宽度算出来的*/
    confirmWords:'拖动滑块验证', /*滑块文字*/
    confirmSuccess:false   /*验证成功判断*/
   }
  },
  methods: {
   mousedownFn:function (e) {
    if(!this.confirmSuccess){
     e.preventDefault && e.preventDefault(); //阻止文字选中等 浏览器默认事件
     this.mouseMoveStata = true;
     this.beginClientX = e.clientX;
    }
   },  //mousedoen 事件
   successFunction(){
    this.confirmSuccess = true
    this.confirmWords = '验证通过';
    if(window.addEventListener){
     document.getElementsByTagName('html')[0].removeEventListener('mousemove',this.mouseMoveFn);
     document.getElementsByTagName('html')[0].removeEventListener('mouseup',this.moseUpFn);
    }else {
     document.getElementsByTagName('html')[0].removeEventListener('mouseup',()=>{});
    }
    document.getElementsByClassName('drag_text')[0].style.color = '#fff'
    document.getElementsByClassName('handler')[0].style.left = this.maxwidth + 'px';
    document.getElementsByClassName('drag_bg')[0].style.width = this.maxwidth + 'px';
   },    //验证成功函数
   mouseMoveFn(e){
    if(this.mouseMoveStata){
     let width = e.clientX - this.beginClientX;
     if(width>0 && width<=this.maxwidth){
      document.getElementsByClassName('handler')[0].style.left = width + 'px';
      document.getElementsByClassName('drag_bg')[0].style.width = width + 'px';
     }else if(width>this.maxwidth){
      this.successFunction();
     }
    }
   },     //mousemove事件
   moseUpFn(e){
    this.mouseMoveStata = false;
    var width = e.clientX - this.beginClientX;
    if(width<this.maxwidth){
     document.getElementsByClassName('handler')[0].style.left = 0 + 'px';
     document.getElementsByClassName('drag_bg')[0].style.width = 0 + 'px';
    }
   }      //mouseup事件
  },
  mounted(){
   this.maxwidth = this.$refs.dragDiv.clientWidth - this.$refs.moveDiv.clientWidth;
   document.getElementsByTagName('html')[0].addEventListener('mousemove',this.mouseMoveFn);
   document.getElementsByTagName('html')[0].addEventListener('mouseup',this.moseUpFn)
  }
 }
</script>

<style scoped>
 .drag{
  position: relative;
  background-color: #e8e8e8;
  width: 100%;
  height: 34px;
  line-height: 34px;
  text-align: center;
 }
 .handler{
  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{
  background-color: #7ac23c;
  height: 34px;
  width: 0px;
 }
 .drag_text{
  position: absolute;
  top: 0px;
  width: 100%;text-align: center;
  -moz-user-select: none;
  -webkit-user-select: none;
  user-select: none;
  -o-user-select:none;
  -ms-user-select:none;
 }
</style>

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持三水点靠木。

Javascript 相关文章推荐
用js遍历 table的脚本
Jul 23 Javascript
Javascript 面向对象 继承
May 13 Javascript
input 输入框获得/失去焦点时隐藏/显示文字(jquery版)
Apr 02 Javascript
jQuery实现字符串按指定长度加入特定内容的方法
Mar 11 Javascript
js数组与字符串常用方法总结
Jan 13 Javascript
jQuery+PHP+Mysql实现抽奖程序
Apr 12 jQuery
激动人心的 Angular HttpClient的源码解析
Jul 10 Javascript
react native仿微信PopupWindow效果的实例代码
Aug 07 Javascript
ES6 如何改变JS内置行为的代理与反射
Feb 11 Javascript
Vue.js + Nuxt.js 项目中使用 Vee-validate 表单校验
Apr 22 Javascript
keep-alive保持组件状态的方法
Dec 02 Javascript
JavaScript流程控制(分支)
Dec 06 Javascript
微信小程序实现图片选择并预览功能
Jul 25 #Javascript
详细教你微信公众号正文页SVG交互开发技巧
Jul 25 #Javascript
微信小程序绘制图片发送朋友圈
Jul 25 #Javascript
微信小程序使用canvas自适应屏幕画海报并保存图片功能
Jul 25 #Javascript
微信小程序实现动态列表项的顺序加载动画
Jul 25 #Javascript
JS查找孩子节点简单示例
Jul 25 #Javascript
微信小程序自定义单项选择器样式
Jul 25 #Javascript
You might like
对于PHP 5.4 你必须要知道的
2013/08/07 PHP
php限制文件下载速度的代码
2015/10/20 PHP
php过滤所有的空白字符(空格、全角空格、换行等)
2015/10/27 PHP
PHP调用存储过程返回值不一致问题的解决方法分析
2016/04/26 PHP
Javascript MD4
2006/12/20 Javascript
javascript 文档的编码问题解决
2009/03/01 Javascript
JS 各种网页尺寸判断实例方法
2013/04/18 Javascript
js的隐含参数(arguments,callee,caller)使用方法
2014/01/28 Javascript
JS在可编辑的div中的光标位置插入内容的方法
2014/11/20 Javascript
javascript中Math.random()使用详解
2015/04/15 Javascript
jquery实现倒计时效果
2015/12/14 Javascript
AngularJS实现进度条功能示例
2017/07/05 Javascript
JavaScript学习笔记之数组基本操作示例
2019/01/09 Javascript
如何换个角度使用VUE过滤器详解
2019/09/11 Javascript
改变layer confirm弹窗按钮的颜色方法
2019/09/12 Javascript
Vue3.x源码调试的实现方法
2019/10/13 Javascript
基于js实现逐步显示文字输出代码实例
2020/04/02 Javascript
python生成日历实例解析
2014/08/21 Python
在python中安装basemap的教程
2018/09/20 Python
python实现转盘效果 python实现轮盘抽奖游戏
2019/01/22 Python
Python测试模块doctest使用解析
2019/08/10 Python
pytorch自定义初始化权重的方法
2019/08/17 Python
Python Selenium XPath根据文本内容查找元素的方法
2020/12/07 Python
详解numpy1.19.4与python3.9版本冲突解决
2020/12/15 Python
css3实现画半圆弧线的示例代码
2017/11/06 HTML / CSS
Noon埃及:埃及在线购物
2019/11/26 全球购物
澳大利亚厨房和家用电器购物网站:Bing Lee
2021/01/11 全球购物
Ejb技术面试题
2015/04/29 面试题
高中的职业生涯规划书
2013/12/28 职场文书
老总助理工作岗位职责
2014/02/06 职场文书
交通局领导班子群众路线教育实践活动对照检查材料思想汇报
2014/10/09 职场文书
工作能力自我评价2015
2015/03/05 职场文书
公司行政主管岗位职责
2015/04/09 职场文书
2016护理专业求职自荐书
2016/01/28 职场文书
七年级英语教学反思
2016/02/15 职场文书
MySql 缓存查询原理与缓存监控和索引监控介绍
2021/07/02 MySQL