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 Elenent实现表格相同数据列合并
Nov 30 Vue.js
vue-router定义元信息meta操作
Dec 07 Vue.js
vue添加自定义右键菜单的完整实例
Dec 08 Vue.js
梳理一下vue中的生命周期
Dec 30 Vue.js
vue中实现点击空白区域关闭弹窗的两种方法
Dec 30 Vue.js
vue集成一个支持图片缩放拖拽的富文本编辑器
Jan 29 Vue.js
vue 使用 v-model 双向绑定父子组件的值遇见的问题及解决方案
Mar 01 Vue.js
详解Vue slot插槽
Nov 20 Vue.js
Vue.Draggable实现交换位置
Apr 07 Vue.js
vue 实现弹窗关闭后刷新效果
Apr 08 Vue.js
vue实力踩坑之push当前页无效
Apr 10 Vue.js
vue+elementUI实现表格列的显示与隐藏
Apr 13 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
自己前几天写的无限分类类
2007/02/14 PHP
ThinkPHP之getField详解
2014/06/20 PHP
PHP中使用sleep函数实现定时任务实例分享
2014/08/21 PHP
php实现用已经过去多长时间的方式显示时间
2015/06/05 PHP
PHP实现通过正则表达式替换回调的内容标签
2015/06/15 PHP
PHP技术开发微信公众平台
2015/07/22 PHP
php引用和拷贝的区别知识点总结
2019/09/23 PHP
js中widow.open()方法使用详解
2013/07/30 Javascript
js实现div在页面拖动效果
2016/05/04 Javascript
JavaScript模板引擎Template.js使用详解
2016/12/15 Javascript
Node.js使用gm拼装sprite图片
2017/07/04 Javascript
用jQuery将JavaScript对象转换为querystring查询字符串的方法
2018/11/12 jQuery
vue 实现购物车总价计算
2019/11/06 Javascript
vue 在单页面应用里使用二级套嵌路由
2020/12/19 Vue.js
python正则表达式去掉数字中的逗号(python正则匹配逗号)
2013/12/25 Python
Python安装官方whl包和tar.gz包的方法(推荐)
2017/06/04 Python
Python 将RGB图像转换为Pytho灰度图像的实例
2017/11/14 Python
Python竟能画这么漂亮的花,帅呆了(代码分享)
2017/11/15 Python
使用Eclipse如何开发python脚本
2018/04/11 Python
django缓存配置的几种方法详解
2018/07/16 Python
Python字符串、整数、和浮点型数相互转换实例
2018/08/04 Python
pyqt5实现按钮添加背景图片以及背景图片的切换方法
2019/06/13 Python
Python使用正则表达式分割字符串的实现方法
2019/07/16 Python
简单了解pytest测试框架setup和tearDown
2020/04/14 Python
Python获取excel内容及相关操作代码实例
2020/08/10 Python
Sentry错误日志监控使用方法解析
2020/11/12 Python
css3实现可拖动的魔方3d效果
2019/05/07 HTML / CSS
HTML5 transform三维立方体实现360无死角三维旋转效果
2014/08/22 HTML / CSS
德国奢侈品网上商城:Mytheresa
2016/08/24 全球购物
美国电子产品购物网站:BuyDig.com
2020/06/17 全球购物
化工专业应届生求职信
2013/11/08 职场文书
《闻一多先生的说和做》教学反思
2014/04/28 职场文书
经典搞笑版检讨书
2015/02/19 职场文书
实验室安全管理制度
2015/08/05 职场文书
vue实现无缝轮播效果(跑马灯)
2021/05/14 Vue.js
为Java项目添加Redis缓存的方法
2021/05/18 Redis