vue实现移动端div拖动效果


Posted in Vue.js onMarch 03, 2022

本文实例为大家分享了vue实现移动端div拖动的具体代码,供大家参考,具体内容如下

手机上会偶尔用到拖动div的效果,虽然我自己还没遇到,先写一个以防万一,需要注明的是,具体实现代码是我在网上找的,但是那个代码存在一些问题,我又搜集了其他资料对其修改,达到了现在的样子,所以还是要感谢写这段代码的大神与万能的搜索引擎

1、分享代码

html代码

<template>
  <div class="main">
    <div ref="move_div" @touchstart="down" @touchmove="move" @touchend="end" :style="{top: top  + 'px', left: left  + 'px'}" class="drag_area"></div>
  </div>
</template>

极其简单的结构,毕竟只是个DEMO

SCSS代码

.main{
    background-color: brown;
    height: -webkit-fill-available;
    .drag_area{
      width: 10vw;
      height: 10vw;
      background-color: dodgerblue;
      position: absolute;
      top: 0;
      left: 0;
    }
  }

为了截图显眼,特地给main加了个背景颜色

效果图

vue实现移动端div拖动效果

效果呢,就是你可以在屏幕范围内自由拖动蓝色色块,不过超出屏幕区域我特意做了限制,不需要限制的可以自己改

JS代码

export default {
  name: 'drag',
  data () {
    return {
      flags: false,
      position: {x: 0, y: 0, left: 0, top: 0},
      top: 0,
      left: 0,
      width: window.innerWidth || document.documentElement.clientWidth || document.body.clientWidth,
      height: window.innerHeight || document.documentElement.clientHeight || document.body.clientHeight
    }
  },
  methods: {
    down () { // 拖动开始的操作
      this.flags = true
      const refs = this.$refs.move_div.getBoundingClientRect()
      let touch = event
      if (event.touches) {
        touch = event.touches[0]
      }
      this.position.x = touch.clientX
      this.position.y = touch.clientY
      this.position.left = refs.left
      this.position.top = refs.top
    },
    move () { // 拖动中的操作
      if (this.flags) {
        let touch = event
        if (event.touches) {
          touch = event.touches[0]
        }
        const xPum = this.position.left + touch.clientX - this.position.x
        const yPum = this.position.top + touch.clientY - this.position.y
        this.left = xPum
        this.top = yPum
        this.banOut()
        // 阻止页面的滑动默认事件
        document.addEventListener('touchmove', function () {
          event.preventDefault()
        }, {passive: false})
      }
    },
    end () { // 拖动结束的操作
      this.flags = false
      this.banOut()
    },
    banOut () { // 避免拖动出界的限制
      const refs = this.$refs.move_div.getBoundingClientRect()
      if (this.left < 0) {
        this.left = 0
      } else if (this.left > this.width - refs.width) {
        this.left = this.width - refs.width
      }
      if (this.top < 0) {
        this.top = 0
      } else if (this.top > this.height - refs.height) {
        this.top = this.height - refs.height
      }
    }
  }
}

代码呢,简洁明了,你要是对touch事件有学习需求呢可以自己琢磨,要是只是要用呢,复制粘贴改一改就行了。

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

Vue.js 相关文章推荐
vue+vant实现购物车全选和反选功能
Nov 17 Vue.js
Vue实现购物小球抛物线的方法实例
Nov 22 Vue.js
Vue实现点击当前行变色
Dec 14 Vue.js
vue自定义组件实现双向绑定
Jan 13 Vue.js
解决vue项目本地启动时无法携带cookie的问题
Feb 06 Vue.js
详解Vue3.0 + TypeScript + Vite初体验
Feb 22 Vue.js
浅谈vue2的$refs在vue3组合式API中的替代方法
Apr 18 Vue.js
关于vue中如何监听数组变化
Apr 28 Vue.js
vue完美实现el-table列宽自适应
May 08 Vue.js
vue-cli4.5.x快速搭建项目
May 30 Vue.js
vue3获取当前路由地址
Feb 18 Vue.js
vue代码分块和懒加载非必要资源文件
Apr 11 Vue.js
vue实现滑动解锁功能
Vue全局事件总线你了解吗
Feb 24 #Vue.js
Vue的生命周期一起来看看
Vue的过滤器你真了解吗
Feb 24 #Vue.js
Vue监视数据的原理详解
Feb 24 #Vue.js
Vue的列表之渲染,排序,过滤详解
Vue3如何理解ref toRef和toRefs的区别
Feb 18 #Vue.js
You might like
如何将数据从文本导入到mysql
2006/10/09 PHP
php利用cookie实现访问次数统计代码
2011/05/19 PHP
深入分析PHP引用(&amp;)
2014/09/04 PHP
深入理解Yii2.0乐观锁与悲观锁的原理与使用
2017/07/26 PHP
html中的input标签的checked属性jquery判断代码
2012/09/19 Javascript
jQuery 回车事件enter使用示例
2014/02/18 Javascript
Javascript中引用示例介绍
2014/02/21 Javascript
jQuery构造函数init参数分析续
2015/05/13 Javascript
浅析C/C++,Java,PHP,JavaScript,Json数组、对象赋值时最后一个元素后面是否可以带逗号
2016/03/22 Javascript
Web程序员必备的7个JavaScript函数
2016/06/14 Javascript
jQuery延迟执行的实现方法
2016/12/21 Javascript
ES6中参数的默认值语法介绍
2017/05/03 Javascript
Node.js操作redis实现添加查询功能
2017/05/25 Javascript
jQuery实现frame之间互通的方法
2017/06/26 jQuery
关于Stream和Buffer的相互转换详解
2017/07/26 Javascript
angularjs http与后台交互的实现示例
2018/12/21 Javascript
jQuery事件委托代码实践详解
2019/06/21 jQuery
绘制微信小程序验证码功能的实例代码
2021/01/05 Javascript
开始着手第一个Django项目
2015/07/15 Python
python中正则表达式 re.findall 用法
2018/10/23 Python
浅谈python图片处理Image和skimage的区别
2019/08/04 Python
django 配置阿里云OSS存储media文件的例子
2019/08/20 Python
python实现XML解析的方法解析
2019/11/16 Python
python中with语句结合上下文管理器操作详解
2019/12/19 Python
python处理RSTP视频流过程解析
2020/01/11 Python
pycharm永久激活超详细教程
2020/10/29 Python
IE9对HTML5中部分属性不支持的原因分析
2014/10/15 HTML / CSS
Lands’ End英国官方网站:高质量男女服装
2017/10/07 全球购物
酒店行政人事部经理职务说明书
2014/02/26 职场文书
项目采购员岗位职责
2014/04/15 职场文书
2015年转正工作总结范文
2015/04/02 职场文书
小学教师见习总结
2015/06/23 职场文书
2016年中秋祝酒词
2015/11/26 职场文书
python生成随机数、随机字符、随机字符串
2021/04/06 Python
解决Navicat for Mysql连接报错1251的问题(连接失败)
2021/05/27 MySQL
javascript canvas实现雨滴效果
2021/06/09 Javascript