当前位置:首页 > VUE

vue实现拖拽属性

2026-01-19 02:38:31VUE

Vue 实现拖拽功能的方法

Vue 中实现拖拽功能可以通过原生 HTML5 的拖拽 API 或第三方库如 vuedraggable 来完成。以下是两种常见的实现方式:

使用 HTML5 拖拽 API

HTML5 提供了原生的拖拽 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');
      console.log(`Dropped item with ID: ${itemId}`);
    },
  },
};
</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实现拖拽属性

安装 vuedraggable

npm install vuedraggable

示例代码:

<template>
  <div>
    <h3>可拖拽列表</h3>
    <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>

注意事项

  • 兼容性:HTML5 拖拽 API 在现代浏览器中支持良好,但在移动端可能表现不一致。
  • 性能:对于大型列表,vuedraggable 性能更优,因其基于 Sortable.js 实现。
  • 事件处理:拖拽过程中需注意事件冒泡和默认行为的阻止(如 @dragover.prevent)。

以上两种方法可根据需求选择,简单场景用 HTML5 API,复杂列表拖拽推荐 vuedraggable

标签: 拖拽属性
分享给朋友:

相关文章

js 实现拖拽

js 实现拖拽

实现拖拽的基本步骤 在JavaScript中实现拖拽功能需要监听几个关键事件:mousedown、mousemove和mouseup。以下是实现的基本逻辑。 监听目标元素的mousedown事件,记…

vue中实现拖拽

vue中实现拖拽

Vue 中实现拖拽功能的方法 在 Vue 中实现拖拽功能可以通过多种方式完成,以下是几种常见的方法: 使用 HTML5 原生拖拽 API HTML5 提供了原生的拖拽 API,可以直接在 Vue…

Vue实现拖拽布局

Vue实现拖拽布局

Vue 实现拖拽布局的方法 使用 HTML5 原生拖拽 API HTML5 提供了原生的拖拽 API,可以通过 draggable 属性、dragstart、dragend、dragover 和 dr…

vue实现拖拽表格

vue实现拖拽表格

Vue 实现拖拽表格的方法 使用第三方库(推荐) 推荐使用 vuedraggable 或 sortablejs 这类成熟的拖拽库,它们对 Vue 有良好支持且功能丰富。 安装 vuedraggabl…

div拖拽实现vue

div拖拽实现vue

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

vue实现自由拖拽

vue实现自由拖拽

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