当前位置:首页 > VUE

vue实现拖动

2026-01-13 00:48:44VUE

Vue 实现拖动的几种方法

使用 HTML5 原生拖放 API

HTML5 提供了原生拖放 API,可以通过 draggable 属性、dragstartdragenddragoverdrop 事件实现基础拖放功能。

<template>
  <div 
    draggable="true"
    @dragstart="handleDragStart"
    @dragend="handleDragEnd"
  >
    可拖拽元素
  </div>
  <div 
    @dragover.prevent
    @drop="handleDrop"
  >
    放置区域
  </div>
</template>

<script>
export default {
  methods: {
    handleDragStart(e) {
      e.dataTransfer.setData('text/plain', 'drag-data')
    },
    handleDrop(e) {
      const data = e.dataTransfer.getData('text/plain')
      console.log('接收到的数据:', data)
    }
  }
}
</script>

使用第三方库 Vue.Draggable

Vue.Draggable 是基于 Sortable.js 的 Vue 组件,适合实现列表排序等复杂拖拽场景。

安装依赖:

vue实现拖动

npm install vuedraggable

使用示例:

<template>
  <draggable 
    v-model="list"
    @end="onDragEnd"
  >
    <div v-for="item in list" :key="item.id">
      {{ item.name }}
    </div>
  </draggable>
</template>

<script>
import draggable from 'vuedraggable'

export default {
  components: { draggable },
  data() {
    return {
      list: [
        { id: 1, name: 'Item 1' },
        { id: 2, name: 'Item 2' }
      ]
    }
  },
  methods: {
    onDragEnd() {
      console.log('排序后的列表:', this.list)
    }
  }
}
</script>

使用鼠标事件实现自定义拖拽

通过监听 mousedownmousemovemouseup 事件可以实现更灵活的拖拽效果。

vue实现拖动

<template>
  <div 
    ref="draggable"
    class="draggable-item"
    @mousedown="startDrag"
  >
    自定义拖拽元素
  </div>
</template>

<script>
export default {
  data() {
    return {
      isDragging: false,
      startX: 0,
      startY: 0,
      offsetX: 0,
      offsetY: 0
    }
  },
  mounted() {
    document.addEventListener('mousemove', this.onDrag)
    document.addEventListener('mouseup', this.stopDrag)
  },
  beforeDestroy() {
    document.removeEventListener('mousemove', this.onDrag)
    document.removeEventListener('mouseup', this.stopDrag)
  },
  methods: {
    startDrag(e) {
      this.isDragging = true
      this.startX = e.clientX
      this.startY = e.clientY
      const rect = this.$refs.draggable.getBoundingClientRect()
      this.offsetX = this.startX - rect.left
      this.offsetY = this.startY - rect.top
    },
    onDrag(e) {
      if (!this.isDragging) return
      const x = e.clientX - this.offsetX
      const y = e.clientY - this.offsetY
      this.$refs.draggable.style.transform = `translate(${x}px, ${y}px)`
    },
    stopDrag() {
      this.isDragging = false
    }
  }
}
</script>

<style>
.draggable-item {
  position: absolute;
  cursor: move;
  user-select: none;
}
</style>

使用拖拽手势库

对于移动端或需要手势支持的场景,可以使用 hammer.js 等手势库。

安装依赖:

npm install hammerjs

使用示例:

<template>
  <div ref="panElement" class="draggable">
    支持手势拖拽的元素
  </div>
</template>

<script>
import Hammer from 'hammerjs'

export default {
  mounted() {
    const hammer = new Hammer(this.$refs.panElement)
    hammer.get('pan').set({ direction: Hammer.DIRECTION_ALL })

    let posX = 0
    let posY = 0

    hammer.on('panmove', (e) => {
      posX += e.deltaX
      posY += e.deltaY
      this.$refs.panElement.style.transform = `translate(${posX}px, ${posY}px)`
    })

    hammer.on('panend', () => {
      // 拖拽结束处理
    })
  }
}
</script>

选择建议

  • 简单拖放:使用 HTML5 原生 API
  • 列表排序:选择 Vue.Draggable
  • 自定义需求:基于鼠标事件实现
  • 移动端支持:考虑手势库方案

每种方案都有其适用场景,可根据具体项目需求选择合适的实现方式。

标签: 拖动vue
分享给朋友:

相关文章

vue实现文档导入

vue实现文档导入

Vue 实现文档导入的方法 在 Vue 中实现文档导入功能通常涉及文件上传、解析和处理。以下是几种常见的方法: 使用原生文件输入和 FileReader 通过 HTML 的原生 <input…

vue实现多层评论回复

vue实现多层评论回复

Vue 实现多层评论回复 数据结构设计 多层评论通常采用嵌套结构,每个评论对象包含子评论数组。示例数据结构如下: comments: [ { id: 1, content: '…

在线脑图 vue 实现

在线脑图 vue 实现

在线脑图 Vue 实现方案 使用开源库实现 推荐使用 mind-elixir 或 jsmind 这类开源库,它们专为脑图设计且支持 Vue 集成。 安装依赖: npm install mind…

vue登录业务的实现

vue登录业务的实现

实现登录业务的基本流程 在Vue中实现登录业务通常涉及前端界面设计、表单验证、API请求交互、状态管理以及路由控制等环节。以下是核心实现步骤: 登录表单设计与验证 创建包含用户名和密码输入框的登录…

vue实现录音文件播放

vue实现录音文件播放

使用 Vue 实现录音文件播放 准备工作 确保项目中已安装必要的依赖,如 vue-audio-recorder 或原生 Web Audio API。录音文件播放通常涉及录音、存储和播放三个核心环节。…

vue实现点击旋转轮盘

vue实现点击旋转轮盘

实现点击旋转轮盘效果 在Vue中实现点击旋转轮盘效果,可以通过CSS动画和Vue的数据绑定结合完成。以下是一个完整的实现方案: 准备工作 需要安装Vue.js环境,可以通过CDN引入或使用Vue…