elmentui树形表格使用Sortable拖拽展开行时拖拽bug

1、使用elemntui的el-table使用Sortable进行拖拽,如下

javascript 复制代码
const el = this.$el.querySelector('.el-table__body-wrapper tbody')
Sortable.create(el, {
  onEnd: (event) => {
    const { oldIndex, newIndex } = event
    //拿到更新前后的下标即可完成数据的更新
  }
})

2、但是我这个需求有点特俗,这个table是一个展开行表格,如下:
3、每次当表格展开的时候,因为展开的数据和要拖拽表格数据同属于拖拽元素,所以每次都可以展开内容,这个是不允许的,所以我需要在展开的时候禁止拖拽

4、解决方式:先把这个拖拽对象赋值给vue的一个属性,然后在展开的时候把这个拖拽对象销毁,所有的展开行都关闭的时候再生成一下拖拽对象

javascript 复制代码
// 假设 sortable 是 Sortable.create 返回的对象
var sortable = Sortable.create(/* ... */);

// 关闭整个列表的拖拽功能
sortable.destroy();
相关推荐
S***t7141 小时前
Vue面试经验
javascript·vue.js·面试
粉末的沉淀1 小时前
css:制作带边框的气泡框
前端·javascript·css
p***h6433 小时前
JavaScript在Node.js中的异步编程
开发语言·javascript·node.js
N***73853 小时前
Vue网络编程详解
前端·javascript·vue.js
q***38514 小时前
TypeScript 与后端开发Node.js
javascript·typescript·node.js
Nan_Shu_6145 小时前
学习:Sass
javascript·学习·es6
WYiQIU5 小时前
面了一次字节前端岗,我才知道何为“造火箭”的极致!
前端·javascript·vue.js·react.js·面试
qq_316837755 小时前
uniapp 观察列表每个元素的曝光时间
前端·javascript·uni-app
小夏同学呀5 小时前
在 Vue 2 中实现 “点击下载条码 → 打开新窗口预览 → 自动唤起浏览器打印” 的功能
前端·javascript·vue.js
芳草萋萋鹦鹉洲哦5 小时前
【vue】导航栏变动后刷新router的几种方法
前端·javascript·vue.js