vue + vuedraggable 实现拖拽排序

本文介绍如何在Vue.js项目中安装并使用Vue.Draggable组件,实现元素的拖拽排序功能。通过npm安装,引入并在组件中注册Vue.Draggable,设置v-model和options选项来定制拖拽行为。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

安装

npm install vuedraggable

引入

import draggable from 'vuedraggable'

注册

components: {
    draggable
}

html

<draggable
    class="list"
    v-model="modules"
    :clone="clone"
    :options="{
        group: {
            name: 'layout',
            pull: 'clone',
            put: false
        },
        draggable: '.item',
        forceFallback: true,
        sort: false,
        animation: 50
    }">
    <transition-group tag="ul">
        <li
            v-for="(item, index) in modules"
            :key="index"
            class="item">
            <div class="holder">
                <img :src="item.icon" />
                <h3>{{item.text}}</h3>
            </div>
        </li>
    </transition-group>
</draggable>

相关文档

官方地址:https://sortablejs.github.io/Vue.Draggable/#/simple

Github:https://github.com/SortableJS/Vue.Draggable

Demo:https://david-desmaisons.github.io/draggable-example/

### 实现 Vue3 + TypeScript + Ant Design + Vuedraggable 的 A-Table 行拖拽排序功能 在 Vue3 项目中结合 TypeScript、Ant Design VueVuedraggable 实现 `a-table` 的行拖拽排序功能,可以通过以下方式实现: #### 1. 使用 Vuedraggable 包裹表格行 使用 `vuedraggable` 的 `tag="tbody"` 属性将表格行包裹,通过 `v-model` 绑定数据源实现拖拽排序功能。该方式能够有效控制行的顺序,并通过 `ghost-class` 提供拖拽时的视觉反馈。 ```vue <template> <a-table :columns="columns" :dataSource="dataSource" :customRow="() => ({ style: { cursor: 'move' } })"> <template #body> <draggable v-model="dataSource" tag="tbody" ghost-class="ghost" handle=".drag-handle" @change="onDragChange"> <tr v-for="(item, index) in dataSource" :key="item.key" class="ant-table-row"> <td class="drag-handle">☰</td> <td>{{ item.name }}</td> <td>{{ item.age }}</td> <td>{{ item.address }}</td> </tr> </draggable> </template> </a-table> </template> ``` #### 2. 数据源与响应式绑定 在 `setup` 中定义 `dataSource` 为 `ref`,确保其为响应式数据,并通过 `v-model` 与 `draggable` 进行双向绑定,实现拖拽后数据源的自动更新。 ```ts <script> import { ref } from 'vue'; import draggable from 'vuedraggable'; export default { components: { draggable }, setup() { const columns = [ { title: '操作', dataIndex: 'action', key: 'action', width: 60 }, { title: '姓名', dataIndex: 'name', key: 'name' }, { title: '年龄', dataIndex: 'age', key: 'age' }, { title: '地址', dataIndex: 'address', key: 'address' } ]; const dataSource = ref([ { key: '1', name: '张三', age: 32, address: '北京市' }, { key: '2', name: '李四', age: 28, address: '上海市' }, { key: '3', name: '王五', age: 30, address: '广州市' } ]); const onDragChange = (event) => { console.log('拖拽发生变化:', event); }; return { columns, dataSource, onDragChange }; } }; </script> ``` #### 3. 自定义行样式与拖拽手柄 通过 `customRow` 设置行样式,增强交互体验。使用 `handle=".drag-handle"` 指定拖拽手柄,避免误触发,确保仅在特定列允许拖拽操作。 ```ts :customRow="() => ({ style: { cursor: 'move' } })" ``` 同时,在行中添加一个 `td` 作为拖拽手柄,并设置样式以提升用户体验: ```html <td class="drag-handle">☰</td> ``` ```css .drag-handle { cursor: move; padding: 8px; background-color: #f0f0f0; } ``` #### 4. 控制某些列不可拖拽 如果需要控制某些列不可拖拽,可以在 `customRow` 中结合 `onmouseenter` 与 `onmouseleave` 动态修改行的 `draggable` 属性,如下所示: ```ts const customRow = (record: any, index: any) => { return { style: { cursor: 'default' }, onmouseenter: (event: any) => { const ev = event || window.event; ev && ev.stopPropagation(); const nowRow = ev?.target?.closest('tr.ant-table-row'); nowRow.draggable = false; nowRow.style.cursor = 'default'; }, onmouseleave: (event: any) => { const ev = event || window.event; ev && ev.stopPropagation(); const nowRow = ev?.target?.closest('tr.ant-table-row'); nowRow.draggable = true; nowRow.style.cursor = 'move'; } }; }; ``` #### 5. 拖拽事件处理 通过 `@change="onDragChange"` 监听拖拽变化事件,可以在控制台输出拖拽详情,也可用于持久化数据更新。 ```ts const onDragChange = (event) => { console.log('拖拽发生变化:', event); }; ``` #### 6. TypeScript 类型定义 为确保类型安全,可以定义数据源的类型: ```ts interface TableRow { key: string; name: string; age: number; address: string; } ``` 并在 `dataSource` 中使用: ```ts const dataSource = ref<TableRow[]>([ { key: '1', name: '张三', age: 32, address: '北京市' }, { key: '2', name: '李四', age: 28, address: '上海市' }, { key: '3', name: '王五', age: 30, address: '广州市' } ]); ``` ### 总结 通过上述方式,可以在 Vue3 + TypeScript + Ant Design Vue + Vuedraggable 的项目中实现 `a-table` 的行拖拽排序功能。结合 `vuedraggable` 的拖拽能力与 `customRow` 的自定义逻辑,可以灵活控制拖拽行为并提升用户体验。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值