当前位置:首页 > 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实现登录功能需要结合前端框架和后端API交互。以下是一个典型的实现方案: 安装必要依赖 确保项目已安装axios用于HTTP请求: npm install a…

vue实现发送值接受值

vue实现发送值接受值

Vue 实现父子组件传值 父组件向子组件传值(props) 父组件通过 v-bind 或简写 : 向子组件传递数据。子组件通过 props 接收数据。 父组件代码: <templat…

vue实现键盘

vue实现键盘

Vue 实现键盘功能 在Vue中实现键盘功能通常涉及监听键盘事件、处理输入以及渲染虚拟键盘界面。以下是几种常见的实现方式: 监听键盘事件 通过@keydown或@keyup指令监听键盘事件,适用于需…

vue实现订单

vue实现订单

Vue 实现订单功能 订单数据结构设计 订单数据通常包含以下字段: order: { id: String, // 订单ID userId: String,…

vue observer实现

vue observer实现

Vue Observer 实现原理 Vue 的响应式系统核心是通过 Object.defineProperty(Vue 2)或 Proxy(Vue 3)实现的 Observer 模式。以下是关键实现细…

vue实现开关

vue实现开关

Vue 实现开关组件的方法 使用原生HTML和Vue数据绑定 通过v-model绑定复选框的checked状态,结合CSS样式实现开关效果: <template> <label…