Vue Element-ui el-table sortablejs 表格拖拽排序

14 篇文章 0 订阅
4 篇文章 0 订阅

首先要在项目中本地安装 sortablejs:

执行 :npm install sortablejs --save

然后在要实现表格拖拽的.vue文件中 引入 sortablejs:

import Sortable from 'sortablejs'

基本排序功能 templete里面的 表格(el-table)不需要进行设置。

 

只需要在vue  的 mounted 方法中 进行sortable的初始化:

 

let el = document.querySelectorAll('.el-table__body-wrapper > table > tbody')[0];

const sortable = Sortable.create(el, {

onEnd: (evt) => { //监听拖动结束事件

console.log(this) //this是当前vue上下文

console.log(evt.oldIndex) //当前行的被拖拽前的顺序

console.log(evt.newIndex) //当前行的被拖拽后的顺序

// 这里就可以写我们需要传给后台的逻辑代码

},

})

 

在页面中进行调试,鼠标可以拖动一行移动到另一行上(下)。说明功能实现了。

//evt.oldIndex 是当前拖动的行,evt.newIndex是放置到的位置。

//有了evt.oldIndex和evt.newIndex这两个参数做索引,我们可以根据绑定在表格上面的data这个Array 找到,两个相应的记录。就可以针对数据进行操作啦。:)

//今天时间比较完了,该收拾收拾下班回家了。以后有机会再发 进一步功能的代码。欢迎大家一起讨论

  • 0
    点赞
  • 5
    收藏
    觉得还不错? 一键收藏
  • 2
    评论
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值