简单vue指令实现 el-table 可拖拽表格功能

安装 SortableJS

sorttableJs 相关优点如下:

相关配置项 参考 👉 SortableJS中文官网

javascript 复制代码
pnpm i sortablejs

封装成指令

不多逼逼,直接上才艺 🤪🤪🤪

先安装一个 nanoid 插件 用于生成随机id,注意事项看源码。

javascript 复制代码
import { nanoid } from 'nanoid';
import Sortable from 'sortablejs';

/**
 * 可拖拽表格指令
 * 使用方式,el-table 标签上添加  v-sort-table="tableData" ,tableData: 表格数据
 * 注意: el-table 要指定 row-key='id'   id 字段为指令内部生成
 * 插件:https://sortablejs.com/
 */

export default {
  name: 'sortTable',
  mounted(el: HTMLElement, binding: { value: Array<any> }) {
    const data = binding.value.map((i) => ({ id: nanoid(8), ...i })); // 处理表格原始数据生成id key
    const targetEl = el.querySelector('.el-table__body-wrapper tbody') as HTMLElement;
    if (targetEl) {
      Sortable.create(targetEl, {
        onEnd(evt) {
          const { oldIndex, newIndex } = evt;
          const movedItem = data.splice(oldIndex as number, 1)[0];
          data.splice(newIndex as number, 0, movedItem);
        },
      });
    }
  },
};

使用

ok 放心拿去造吧🤭

javascript 复制代码
 <el-table
          v-sort-table="$editItem.props"
          :data="$editItem.props"
 </el-table>          
相关推荐
Ziky学习记录5 分钟前
从零到实战:React Router 学习与总结
前端·学习·react.js
wuhen_n11 分钟前
JavaScript链表与双向链表实现:理解数组与链表的差异
前端·javascript
wuhen_n14 分钟前
JavaScript数据结构深度解析:栈、队列与树的实现与应用
前端·javascript
我是一只puppy21 分钟前
使用AI进行代码审查
javascript·人工智能·git·安全·源代码管理
颜酱21 分钟前
从二叉树到衍生结构:5种高频树结构原理+解析
javascript·后端·算法
狗哥哥36 分钟前
微前端路由设计方案 & 子应用管理保活
前端·架构
TT哇1 小时前
【实习 】银行经理端两个核心功能的开发与修复(银行经理绑定逻辑修复和线下领取扫码功能开发)
java·vue.js
前端大卫1 小时前
Vue3 + Element-Plus 自定义虚拟表格滚动实现方案【附源码】
前端
却尘1 小时前
Next.js 请求最佳实践 - vercel 2026一月发布指南
前端·react.js·next.js
ccnocare1 小时前
浅浅看一下设计模式
前端