当前位置:首页 > 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 组件,适合实现列表排序等复杂拖拽场景。

安装依赖:

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 事件可以实现更灵活的拖拽效果。

<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 实现订单功能 数据模型设计 订单功能通常需要设计以下数据结构: // 订单数据结构 const order = { id: '', // 订单ID userId:…

vue实现评论编辑

vue实现评论编辑

Vue 实现评论编辑功能 数据绑定与表单结构 使用 v-model 双向绑定评论内容到表单输入框,确保编辑时能显示原内容并同步修改。示例模板结构: <template> <d…

vue实现前端分离

vue实现前端分离

Vue 实现前后端分离 前后端分离是一种架构模式,前端负责页面渲染和交互逻辑,后端提供数据接口。Vue.js 作为前端框架,非常适合实现前后端分离的开发模式。 核心实现步骤 创建 Vue 项目 使用…

vue实现年历

vue实现年历

Vue 实现年历的方法 使用 Vue 实现年历可以通过组件化开发方式,结合日期计算和动态渲染完成。以下是两种常见的实现方式: 基于原生 Vue 的日历组件 创建 Calendar.vue 组件文件…

vue循环数组实现

vue循环数组实现

vue循环数组的实现方法 在Vue中循环数组主要通过v-for指令实现,以下是几种常见用法: 基本数组循环 使用v-for指令遍历数组,可以通过(item, index)的语法获取当前项和索引值:…

vue实现网页切换

vue实现网页切换

Vue 实现网页切换的方法 在 Vue 中实现网页切换通常可以通过以下几种方式完成,具体取决于项目需求和路由管理方式。 使用 Vue Router Vue Router 是 Vue.js 官方提供…