定义骨架,写html和css

html部分

<template><div class="drag-wrapper" ref="dragDiv"><div class="drag_bg"></div><div class="drag_text f14">{{ confirmWords }}</div><!-- 移动的模块 --><div ref="moveDiv"@mousedown="mousedownFn($event)":class="{'handler_ok_bg': confirmSuccess}"class="handler handler_bg"></div></div>
</template>
复制代码

css部分: 由于担心图片源的问题,所以写成了base64的图片

<style scoped>.drag{position: relative;background-color: #e8e8e8;width: 100%;height: 40px;line-height: 40px;text-align: center;}.handler{width: 40px;height: 40px;border: 1px solid #ccc;cursor: move;position: absolute;top: 0px;left: 0px;}.handler_bg{background: #fff url("") no-repeat center;}.handler_ok_bg{background: #fff url("") no-repeat center;}.drag_bg{background-color: #7ac23c;height: 40px;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>
复制代码

实现滑动拖拽校验

定义参数

data() {return {beginClientX:0,               // 距离屏幕左端距离mouseMoveStata:false,         // 触发拖动状态  判断maxwidth:'',                  // 拖动最大宽度,依据滑块宽度算出来的confirmWords:'拖动滑块验证',   // 滑块文字confirmSuccess:false          // 验证成功判断}
}
复制代码

1. 在mounted里面,根据滑块宽度计算可拖动最大宽度以及监听手指的触摸和离开事件

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)
}
复制代码

2. 编写手指滑动的事件和手指离开的事件

  • mousemove事件

首先判断是否触发拖动状态,然后计算拖动的距离和模块距离,实时赋值

//验证成功函数
mouseMoveFn(e){if(this.mouseMoveStata){let width = e.clientX - this.beginClientXif(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()}
},
复制代码
  • mouseup事件

拖动状态改成false,并且把滑块移到对应的手指落下位置上

moseUpFn(e) {this.mouseMoveState = !1                        // 修改状态const 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'}
}
复制代码

在上面html部分的handler块里,定义了mousedown事件(mousedownFn($event))

需要阻止文件选中等浏览器默认行为,并把触发拖动状态这个阈值打开,记录手指移动的距离

mousedownFn:function (e) {e.preventDefault && e.preventDefault()   // 阻止文字选中等 浏览器默认事件this.mouseMoveStata = true               // 把触发拖动状态这个阈值打开this.beginClientX = e.clientX            // 记录手指移动的距离
},
复制代码

至此,功能就完成了。。

完整的JS代码如下

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

顺便推荐下我的小说网站,欢迎收藏哟

虫鱼小说网

知秋小说网

vue实现滑块拖拽校验相关推荐

  1. vue移动端拖拽悬浮按钮

    vue移动端拖拽悬浮按钮 功能介绍: 大致需求: 整体思路: 简单效果展示: 具体实现: 一.position:fixed布局: 二.touch事件绑定: 三.页面引入: 功能介绍: 在移动端开发中, ...

  2. vue 表格左右拖拽调整列宽_解决 | iview低版本实现表格拖拽,滚动条列宽计算问题...

    文 / 景朝霞 来源公号 / 朝霞的光影笔记 ID / zhaoxiajingjing 点个赞,让我知道你来过~ 如果大佬觉得我的方案太low,请打脸轻一点~ 如果大佬有更好的方案,请不吝赐教~ 0 ...

  3. vue 原型设计 拖拽_Vue 也能实现拖拽了 (vue-dragging)

    前言 vue-dragging 的 npm 包的名字是 awe-dnd,并不是 vue-dragging, 特点 : 封装了 v-dragging 全局指令,然后通过全局指令去数据绑定等. 相比及 v ...

  4. vue可视化拖拽生成工具_vdesjs: 基于vue的可视化拖拽,代码生成工具。提升前端开发效率,或者集成至项目作为在线拖拽工具。(持续迭代升级中)...

    vdesjs 介绍 vdesjs是一款基于vue技术栈,可视化拖拽,代码生成工具.我们提供详细的文档来帮助您理解我们工具的实现原理,并且您可以方便的基于vdesjs来扩展您自己的代码生成组件. 技术选 ...

  5. vuedraggable自由拖拽html,vue中draggable拖拽列表的使用

    1.安装 npm install vuedraggable 或者使用镜像安装 cnpm install vuedraggable 2.使用 首先在使用的组件中引入 import draggable f ...

  6. vue 原型设计 拖拽_设计即开发,如何打通软件研发的“任督二脉”?

    随着信息化技术的深化应用和5G时代的到来,信息化将彻底改变人们的生活.生产和学习方式.软件,作为互联网时代的主角,近几年犹如过江之鲫般产生,层出不穷,让人应接不暇. 一个软件产品的诞生须经历可研.需求 ...

  7. html5 list 拖拽排序,vue实现可拖拽排序的列表

    在做友情链接管理功能的时候,考虑到有个对友情链接排序的需求,开始的时候 我是在这个list 里边加了rank字段,用户需要手动输入rank ,点击保存后,后台通过用户输入的rank序号进行排序,这显然 ...

  8. Vue 实现图片拖拽功能

    功能背景: 需要对导航栏的icon,支持拖拽排序功能,然后自动保存. 原理讲解: 随意拖动一张图到另外一个图片上面时,两张图片交换位置. 原理:现有一个图片的列表,拖动其中一个图片(触发dragsta ...

  9. vue中实现拖拽调整顺序功能

    一.使用vuedraggable是标准的组件式封装 或 vue-dragging 指令方式 实现拖拽调整顺序功能. 1:安装依赖 npm install vuedraggable或yarn add v ...

  10. vue中实现拖拽排序

    原生拖拽 API 实现拖拽 设置元素 dragable 将元素的 dragable 属性设置 为 true (文本 图片 链接 的draggable 属性默认为 true)则元素可拖放 <div ...

最新文章

  1. Product Backlog:终极任务清单
  2. 洗礼灵魂,修炼python(70)--爬虫篇—补充知识:json模块
  3. Python之路【第十二篇】:函数
  4. CYQ.Data 从入门到放弃ORM系列:开篇:自动化框架编程思维
  5. spark submit 入门
  6. 需求调研计划_拆书营销管理 实施营销调研和预测需求
  7. 【AI基础】OpenCV,PIL,Skimage你pick谁
  8. 开源实时音视频技术WebRTC中RTP/RTCP数据传输协议的应用
  9. Cascade R-CNN
  10. java 基础知识巩固_Java基础巩固——《Java核心技术基础·卷一:基础知识》
  11. Apache Tiles的使用 前配置
  12. linux下如何bash文件,Linux系统的文件管理命令及bash的相关工作特性
  13. 西瓜视频4K修复技术还原经典,为内容创新打开新思路
  14. 推挽电源的基本工作原理、磁通不平衡问题及其解决方法
  15. [注]打动我的50句广告语
  16. 英特尔芯片组发展史简介
  17. 路由器网口1一直闪烁正常吗_路由器灯怎么闪才正常
  18. 语句摘抄——第20周
  19. 网络聊天中的英语简写
  20. 人工智能(AI)在游戏中的应用(上)

热门文章

  1. ASRT语音识别asrserver http协议测试专用客户端
  2. vac虚拟声卡我linux,虚拟声卡驱动应用及其原理简要说明
  3. 字符常量与字符串常量
  4. 使用Grafana+loki+promtail入门级部署分布式日志系统(windows环境)
  5. Taro 周报 #7: 收获「e代驾」案例,发布 v2.2.16 和 v3.2.0-canary.2
  6. Windows下安装 rubyinstaller
  7. 节奏大师服务器不稳定,节奏大师无法登陆的原因及解决方法
  8. 这个与流程管理相结合的低代码平台,你一定不能错过
  9. OSX更新后JRE6被删除引发了问题
  10. 解决windows7系统netmeeting无法(安装)使用问题