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中音频wavesurfer.js的使用方法
Feb 20 Vue.js
vue的hash值原理也是table切换实例代码
Dec 14 Vue.js
antdesign-vue结合sortablejs实现两个table相互拖拽排序功能
Jan 08 Vue.js
如何在 Vue 表单中处理图片
Jan 26 Vue.js
vue打开新窗口并实现传参的图文实例
Mar 04 Vue.js
Vue实现下拉加载更多
May 09 Vue.js
Vue Element UI自定义描述列表组件
May 18 Vue.js
vue自定义右键菜单之全局实现
Apr 09 Vue.js
vue组件vue-esign实现电子签名
Apr 21 Vue.js
vue elementUI批量上传文件
Apr 26 Vue.js
vue如何在data中引入图片的正确路径
Jun 05 Vue.js
vue本地构建热更新卡顿的问题“75 advanced module optimization”完美解决方案
Aug 05 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
Oracle Faq(Oracle的版本)
2006/10/09 PHP
PHP 中文乱码解决办法总结分析
2009/07/30 PHP
完美解决phpdoc导出文档中@package的warning及Error的错误
2016/05/17 PHP
php操纵mysqli数据库的实现方法
2016/09/18 PHP
laravel中命名路由的使用方法
2017/02/24 PHP
浅谈关于PHP解决图片无损压缩的问题
2017/09/01 PHP
浅谈php常用的7大框架的优缺点
2020/07/20 PHP
24款非常有用的 jQuery 插件分享
2011/04/06 Javascript
jquery实现效果比较好的table选中行颜色
2014/03/25 Javascript
jquery实现点击文字可编辑并修改保存至数据库
2014/04/15 Javascript
js实现鼠标滑过文字链接色彩变化的效果
2015/05/06 Javascript
jQuery焦点图切换特效代码分享
2015/09/15 Javascript
全面介绍vue 全家桶和项目实例
2017/12/27 Javascript
微信小程序如何获取用户收货地址
2018/11/27 Javascript
学习node.js 断言的使用详解
2019/03/18 Javascript
ES2020系列之空值合并运算符 '??'
2020/07/22 Javascript
[01:50:49]DOTA2-DPC中国联赛 正赛 PSG.LGD vs Aster BO3 第三场 1月24日
2021/03/11 DOTA
[01:10:30]DOTA2-DPC中国联赛正赛 Dragon vs Dynasty BO3 第一场 3月4日
2021/03/11 DOTA
Python获取apk文件URL地址实例
2013/11/01 Python
Django框架中的对象列表视图使用示例
2015/07/21 Python
linecache模块加载和缓存文件内容详解
2018/01/11 Python
Python wxpython模块响应鼠标拖动事件操作示例
2018/08/23 Python
用django-allauth实现第三方登录的示例代码
2019/06/24 Python
Python将文字转成语音并读出来的实例详解
2019/07/15 Python
安装PyInstaller失败问题解决
2019/12/14 Python
tensorboard实现同时显示训练曲线和测试曲线
2020/01/21 Python
Python运算符+与+=的方法实例
2021/02/18 Python
使用Html5、CSS实现文字阴影效果
2018/01/17 HTML / CSS
HTML5 form标签之解放表单验证、增加文件上传、集成拖放的使用方法
2013/04/24 HTML / CSS
分享29个基于Bootstrap的HTML5响应式网页设计模板
2015/11/19 HTML / CSS
迪斯尼商品官方网站:ShopDisney
2016/08/01 全球购物
美国优质宠物用品购买网站:Muttropolis
2020/02/17 全球购物
Moda Operandi官网:美国奢侈品电商,海淘秀场T台同款
2020/05/26 全球购物
群众路线领导班子四风对照检查材料
2014/09/27 职场文书
街道办残联2016年助残日活动总结
2016/04/01 职场文书
MySQL系列之开篇 MySQL关系型数据库基础概念
2021/07/02 MySQL