当前位置:首页 > VUE

用vue实现拖拽

2026-03-10 00:22:46VUE

使用 Vue 实现拖拽功能

在 Vue 中实现拖拽功能可以通过原生 HTML5 的拖拽 API 或第三方库如 vuedraggable 来完成。以下是两种方法的详细实现步骤。

原生 HTML5 拖拽 API 实现

原生拖拽 API 主要通过 draggable 属性、dragstartdragenddragoverdrop 事件实现。

用vue实现拖拽

<template>
  <div>
    <div 
      v-for="item in items" 
      :key="item.id"
      draggable="true"
      @dragstart="handleDragStart($event, item)"
      @dragend="handleDragEnd"
      class="draggable-item"
    >
      {{ item.text }}
    </div>
    <div 
      @dragover.prevent
      @drop="handleDrop"
      class="drop-zone"
    >
      拖拽到这里
    </div>
  </div>
</template>

<script>
export default {
  data() {
    return {
      items: [
        { id: 1, text: 'Item 1' },
        { id: 2, text: 'Item 2' },
        { id: 3, text: 'Item 3' }
      ],
      draggedItem: null
    };
  },
  methods: {
    handleDragStart(event, item) {
      this.draggedItem = item;
      event.dataTransfer.setData('text/plain', item.id);
    },
    handleDragEnd() {
      this.draggedItem = null;
    },
    handleDrop(event) {
      event.preventDefault();
      const itemId = event.dataTransfer.getData('text/plain');
      const item = this.items.find(item => item.id === parseInt(itemId));
      if (item) {
        // 处理拖拽逻辑,例如更新数组或触发状态变更
        console.log('Dropped item:', item);
      }
    }
  }
};
</script>

<style>
.draggable-item {
  padding: 8px;
  margin: 4px;
  background: #f0f0f0;
  cursor: move;
}
.drop-zone {
  padding: 20px;
  margin: 10px;
  background: #e0e0e0;
  border: 2px dashed #999;
}
</style>

使用 vuedraggable 库实现

vuedraggable 是一个基于 Sortable.js 的 Vue 拖拽组件,简化了列表拖拽的实现。

用vue实现拖拽

安装依赖:

npm install vuedraggable

示例代码:

<template>
  <div>
    <draggable 
      v-model="items" 
      @end="onDragEnd"
      item-key="id"
    >
      <template #item="{ element }">
        <div class="draggable-item">
          {{ element.text }}
        </div>
      </template>
    </draggable>
  </div>
</template>

<script>
import draggable from 'vuedraggable';
export default {
  components: { draggable },
  data() {
    return {
      items: [
        { id: 1, text: 'Item 1' },
        { id: 2, text: 'Item 2' },
        { id: 3, text: 'Item 3' }
      ]
    };
  },
  methods: {
    onDragEnd() {
      console.log('拖拽后的顺序:', this.items);
    }
  }
};
</script>

<style>
.draggable-item {
  padding: 8px;
  margin: 4px;
  background: #f0f0f0;
  cursor: move;
}
</style>

两种方法的对比

  • 原生 API:适合简单场景,无需额外依赖,但需要手动处理更多细节(如状态管理、样式控制)。
  • vuedraggable:功能强大,支持复杂拖拽逻辑(如跨列表拖拽、动画效果),适合需要快速实现的场景。

根据需求选择合适的方法即可。

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

相关文章

vue实现打印二维码

vue实现打印二维码

安装二维码生成库 使用 qrcode 或 vue-qrcode 库生成二维码。通过 npm 安装: npm install qrcode vue-qrcode 生成二维码 在 Vue 组件中引入…

vue实现粘贴

vue实现粘贴

Vue 实现粘贴功能的方法 在 Vue 中实现粘贴功能通常涉及监听粘贴事件并处理剪贴板数据。以下是几种常见的实现方式: 监听原生粘贴事件 通过 @paste 指令或原生 addEventListen…

vue实现海报

vue实现海报

Vue 实现海报生成方案 使用 html2canvas 库 html2canvas 是一个将 HTML 元素转换为 Canvas 的库,适合将 Vue 组件渲染为海报图片 安装依赖: npm in…

vue实现ssr

vue实现ssr

Vue 实现 SSR(服务端渲染) Vue 的服务端渲染(SSR)允许在服务器端生成完整的 HTML 内容,再发送到客户端,提升首屏加载速度和 SEO 友好性。以下是实现 Vue SSR 的关键步骤和…

vue实现tap

vue实现tap

Vue 实现 Tap 事件 在移动端开发中,Tap 事件比 Click 事件更常用,因为 Click 事件有 300ms 延迟。以下是几种在 Vue 中实现 Tap 事件的方法。 使用第三方库 安装…

vue拼图实现

vue拼图实现

实现 Vue 拼图游戏的方法 使用 Vue 组件和动态数据绑定 创建一个 Vue 组件来管理拼图的状态和逻辑。通过 v-for 动态渲染拼图块,利用 v-bind 绑定样式和位置。拼图块的数据可以存储…