当前位置:首页 > VUE

vue.js实现拖动

2026-02-23 05:45:09VUE

Vue.js 实现拖动的几种方法

使用 HTML5 原生拖放 API

HTML5 提供了原生的拖放 API,可以通过 draggable 属性和相关事件实现拖动功能。

<template>
  <div 
    draggable="true"
    @dragstart="handleDragStart"
    @dragend="handleDragEnd"
  >
    可拖动元素
  </div>
</template>

<script>
export default {
  methods: {
    handleDragStart(event) {
      event.dataTransfer.setData('text/plain', event.target.id)
    },
    handleDragEnd(event) {
      console.log('拖动结束')
    }
  }
}
</script>

使用 Vue.Draggable 库

Vue.Draggable 是一个基于 Sortable.js 的 Vue 组件,提供了更简单的 API 来实现拖动排序功能。

安装 Vue.Draggable:

vue.js实现拖动

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>

自定义拖动实现

对于更复杂的拖动需求,可以结合鼠标事件实现自定义拖动逻辑。

vue.js实现拖动

<template>
  <div
    class="draggable-item"
    @mousedown="startDrag"
    :style="{ left: position.x + 'px', top: position.y + 'px' }"
  >
    拖动我
  </div>
</template>

<script>
export default {
  data() {
    return {
      position: { x: 0, y: 0 },
      isDragging: false,
      startPos: { x: 0, y: 0 }
    }
  },
  methods: {
    startDrag(event) {
      this.isDragging = true
      this.startPos = {
        x: event.clientX - this.position.x,
        y: event.clientY - this.position.y
      }
      document.addEventListener('mousemove', this.onDrag)
      document.addEventListener('mouseup', this.stopDrag)
    },
    onDrag(event) {
      if (this.isDragging) {
        this.position = {
          x: event.clientX - this.startPos.x,
          y: event.clientY - this.startPos.y
        }
      }
    },
    stopDrag() {
      this.isDragging = false
      document.removeEventListener('mousemove', this.onDrag)
      document.removeEventListener('mouseup', this.stopDrag)
    }
  }
}
</script>

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

使用第三方拖拽库

其他流行的拖拽库如 interact.js 也可以与 Vue 配合使用,提供更丰富的拖拽功能。

安装 interact.js:

npm install interactjs

使用示例:

<template>
  <div ref="draggable" class="draggable">
    可交互拖动元素
  </div>
</template>

<script>
import interact from 'interactjs'

export default {
  mounted() {
    interact(this.$refs.draggable)
      .draggable({
        onmove: event => {
          const target = event.target
          const x = (parseFloat(target.getAttribute('data-x')) || 0) + event.dx
          const y = (parseFloat(target.getAttribute('data-y')) || 0) + event.dy

          target.style.transform = `translate(${x}px, ${y}px)`
          target.setAttribute('data-x', x)
          target.setAttribute('data-y', y)
        }
      })
  }
}
</script>

选择建议

  • 简单拖动排序:使用 Vue.Draggable
  • 自定义拖动行为:使用原生 API 或 interact.js
  • 复杂拖放交互:考虑专业拖拽库如 interact.js

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

相关文章

vue怎么实现拖动数据

vue怎么实现拖动数据

Vue 实现拖动数据的方法 使用 HTML5 拖放 API HTML5 提供了原生的拖放 API,可以通过 draggable 属性和相关事件实现拖动功能。 <template> &…

vue computed 实现

vue computed 实现

computed 的基本用法 在 Vue 中,computed 用于声明计算属性,这些属性基于响应式依赖进行缓存。只有当依赖发生变化时,计算属性才会重新计算。 new Vue({ data: {…

vue实现购票

vue实现购票

Vue 实现购票功能 数据结构设计 购票功能通常需要以下数据结构: 场次信息(时间、地点、价格) 座位信息(可选座位、已售座位) 用户订单信息 示例数据结构: data() { return…

vue登录实现

vue登录实现

Vue 登录实现 实现登录功能通常需要前端与后端配合,Vue 作为前端框架,主要负责表单处理、请求发送和状态管理。以下是常见的实现方式: 表单设计与数据绑定 使用 Vue 的 v-model 实现表…

vue实现日历

vue实现日历

Vue 实现日历的基本方法 使用 Vue 实现日历可以通过自定义组件或借助第三方库完成。以下是两种常见实现方式: 自定义日历组件 创建基于 Vue 的日历组件需要处理日期计算和渲染逻辑。核心是生成当…

vue 实现 confirm

vue 实现 confirm

实现确认对话框的方法 在Vue中实现确认对话框可以通过多种方式完成,包括使用内置组件、第三方库或自定义组件。 使用浏览器原生confirm 最简单的实现方式是直接调用浏览器原生的confirm方法。…