当前位置:首页 > VUE

vue 拖拽排序 实现

2026-01-16 00:00:41VUE

实现拖拽排序的基本思路

在Vue中实现拖拽排序通常需要借助HTML5的拖放API或第三方库如sortablejsvuedraggable等。以下是两种常见实现方式:

使用HTML5原生拖放API

通过HTML5的draggable属性结合dragstartdragoverdrop等事件实现基础拖拽排序。

<template>
  <ul>
    <li 
      v-for="(item, index) in list" 
      :key="item.id"
      draggable="true"
      @dragstart="handleDragStart(index)"
      @dragover.prevent="handleDragOver(index)"
      @drop="handleDrop(index)"
    >
      {{ item.name }}
    </li>
  </ul>
</template>

<script>
export default {
  data() {
    return {
      list: [
        { id: 1, name: 'Item 1' },
        { id: 2, name: 'Item 2' },
        { id: 3, name: 'Item 3' }
      ],
      draggedIndex: null
    }
  },
  methods: {
    handleDragStart(index) {
      this.draggedIndex = index
    },
    handleDragOver(index) {
      if (this.draggedIndex !== index) {
        const draggedItem = this.list[this.draggedIndex]
        this.list.splice(this.draggedIndex, 1)
        this.list.splice(index, 0, draggedItem)
        this.draggedIndex = index
      }
    },
    handleDrop() {
      this.draggedIndex = null
    }
  }
}
</script>

使用vuedraggable库

vuedraggable是基于sortablejs的Vue组件,提供更完善的拖拽功能。

安装依赖:

npm install vuedraggable

示例代码:

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

<script>
import draggable from 'vuedraggable'

export default {
  components: { draggable },
  data() {
    return {
      list: [
        { id: 1, name: 'Item 1' },
        { id: 2, name: 'Item 2' },
        { id: 3, name: 'Item 3' }
      ]
    }
  },
  methods: {
    onDragEnd() {
      console.log('排序后的列表:', this.list)
    }
  }
}
</script>

实现表格行拖拽排序

对于表格行的拖拽排序,vuedraggable同样适用:

<template>
  <draggable 
    v-model="tableData" 
    tag="tbody"
    item-key="id"
  >
    <template #item="{ element }">
      <tr>
        <td>{{ element.id }}</td>
        <td>{{ element.name }}</td>
      </tr>
    </template>
  </draggable>
</template>

跨组件拖拽实现

通过Vue的provide/inject或全局状态管理实现跨组件拖拽:

// 父组件
provide() {
  return {
    dragContext: {
      list: this.list,
      updateList: this.updateList
    }
  }
}

// 子组件
inject: ['dragContext']

性能优化建议

对于大数据量列表,使用虚拟滚动技术(如vue-virtual-scroller)结合拖拽功能。限制重渲染范围,避免不必要的计算属性。

移动端适配

移动端需要添加touch事件支持。vuedraggable已内置移动端支持,原生实现需添加touchstarttouchmove等事件处理。

vue 拖拽排序 实现

handleTouchStart(e, index) {
  this.draggedIndex = index
  this.touchStartY = e.touches[0].clientY
}

以上方法可根据具体需求选择实现,第三方库方案通常更完整但会增加包体积,原生API更适合简单场景。

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

相关文章

vue实现引导

vue实现引导

Vue 实现引导功能的方法 使用第三方库 推荐使用 driver.js 或 intro.js 这类专门为 Vue 设计的引导库。这些库提供了完整的 API 和样式,能够快速实现引导功能。 安装 dr…

vue实现拖拉

vue实现拖拉

实现拖拽功能的基本步骤 在Vue中实现拖拽功能可以通过原生HTML5的拖放API或第三方库如vuedraggable完成。以下是两种方法的详细说明。 使用HTML5原生拖放API HTML5提供了原…

vue实现框选

vue实现框选

Vue 实现框选功能 在 Vue 中实现框选功能通常需要监听鼠标事件,计算选区范围,并根据选区范围高亮或选中元素。以下是实现框选功能的关键步骤。 监听鼠标事件 在 Vue 模板中,为容器元素绑定鼠标…

vue实现rem适配

vue实现rem适配

Vue 项目中实现 REM 适配 REM(Root EM)是一种基于根元素(html)字体大小的相对单位,常用于移动端适配。以下是在 Vue 项目中实现 REM 适配的详细方法。 安装 postcs…

js实现拖拽

js实现拖拽

实现拖拽的基本步骤 使用JavaScript实现拖拽功能需要监听鼠标事件,包括mousedown、mousemove和mouseup。以下是实现的基本逻辑: const draggableEleme…

实现vue页面回退

实现vue页面回退

监听浏览器返回事件 在Vue组件中使用beforeRouteLeave导航守卫,可以监听路由变化。该方法在离开当前路由前触发,适用于需要确认或保存数据的场景。 beforeRouteLeave(…