element关于table拖拽排序问题

element关于table拖拽排序问题element关于table拖拽排序问题

大家好,又见面了,我是你们的朋友全栈君。

博客地址:http://www.globm.top/blog/1/detail/41
最近在使用element table的时候,经常会遇到排序的问题,如果只是简单的排序的话,element官方已经给出了指定的方法

//table的默认排序方式是按ID排序 顺序为递减 这里可以改成其它 比如 order
    <el-table :data="tableData" :default-sort="{prop: 'ID', order: 'descending'}">
      //设置sortable属性时出现排序按钮
      <el-table-column prop="ID" label="座号" sortable>
    </el-table>

但是,element官方组件并不支持拖拽排序,我在这里引入sortablejs实现拖拽排序的功能

  • sortablejs GitHub地址
//sortablejs GitHub地址
https://github.com/SortableJS/Sortable#readme
//安装sortable.js
Install with NPM:
$ npm install sortablejs --save
//在组件内引入
import Sortable from 'sortablejs'
//为需要拖拽排序的表格添加ref属性
<el-table  ref="dragTable">
//在数据渲染完毕添加拖拽事件
created(){ 

this.getBanner()
},
methods:{ 

async getBanner(val){ 

await apiGetBanner().then((res)=>{ 

this.bannerTable = res.data.data;
})
this.oldList = this.bannerTable.map(v => v.id);
this.newList = this.oldList.slice();
this.$nextTick(() => { 

this.setSort()  //数据渲染完毕执行方法
})
}
setSort() { 

const el = this.$refs.dragTable.$el.querySelectorAll(
'.el-table__body-wrapper > table > tbody'
)[0];
this.sortable = Sortable.create(el, { 

// Class name for the drop placeholder,
ghostClass: 'sortable-ghost', 
setData: function(dataTransfer) { 

dataTransfer.setData('Text', '')
},
//拖拽结束执行,evt执向拖拽的参数
onEnd: evt => { 

//判断是否重新排序
if(evt.oldIndex !== evt.newIndex){ 

let data = { 

id:this.bannerTable[evt.oldIndex].id,
banner_order:evt.newIndex
}
//数据提交失败则恢复旧的排序
apiPutBanner(data).catch(()=>{ 

const targetRow = this.bannerTable.splice(evt.oldIndex, 1)[0];
this.bannerTable.splice(evt.newIndex, 0, targetRow);
})
}
}
})
}
}

如果需要列拖拽的话,可以参考下面的代码,和上面是一样的原理,在这里我就不赘述了

//行拖拽
rowDrop() { 

const tbody = document.querySelector('.el-table__body-wrapper tbody')
const _this = this
Sortable.create(tbody, { 

onEnd({ 
 newIndex, oldIndex }) { 

const currRow = _this.tableData.splice(oldIndex, 1)[0]
_this.tableData.splice(newIndex, 0, currRow)
}
})
},
//列拖拽
columnDrop() { 

const wrapperTr = document.querySelector('.el-table__header-wrapper tr')
this.sortable = Sortable.create(wrapperTr, { 

animation: 180,
delay: 0,
onEnd: evt => { 

const oldItem = this.dropCol[evt.oldIndex]
this.dropCol.splice(evt.oldIndex, 1)
this.dropCol.splice(evt.newIndex, 0, oldItem)
}
})
}
版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 举报,一经查实,本站将立刻删除。

发布者:全栈程序员-用户IM,转载请注明出处:https://javaforall.cn/149205.html原文链接:https://javaforall.cn

【正版授权,激活自己账号】: Jetbrains全家桶Ide使用,1年售后保障,每天仅需1毛

【官方授权 正版激活】: 官方授权 正版激活 支持Jetbrains家族下所有IDE 使用个人JB账号...

(0)


相关推荐

  • ZOJ问题(坑死了)「建议收藏」

    ZOJ问题(坑死了)「建议收藏」ZOJ问题TimeLimit:2000/1000MS(Java/Others)MemoryLimit:32768/32768K(Java/Others)TotalSubmission

  • 没用过这些 IDEA 插件?怪不得写代码头疼

    没用过这些 IDEA 插件?怪不得写代码头疼使用插件,可以提高开发效率。对于开发人员很有帮助。这篇博客介绍了IDEA中最常用的一些插件。

  • find命令的用法_find命令查找文件

    find命令的用法_find命令查找文件find命令——文件或目录查找而且可以直接对查找结果使用命令。find 查找范围    查找条件                        -name                按名称查找                              -maxdepth     查看多深的文件,不能超过所限制的目录下的内容                   …

    2022年10月14日
  • idea2021.11.3激活(JetBrains全家桶)

    (idea2021.11.3激活)最近有小伙伴私信我,问我这边有没有免费的intellijIdea的激活码,然后我将全栈君台教程分享给他了。激活成功之后他一直表示感谢,哈哈~IntelliJ2021最新激活注册码,破解教程可免费永久激活,亲测有效,下面是详细链接哦~https://javaforall.cn/100143.html08…

  • android浏览器插件介绍

    android浏览器插件介绍一浏览器插件介绍:  1.1概述浏览插件本质是一个功能模块,是浏览器功能的一种扩充。其载体是dll或则so文件。它依附浏览器完成某一特定的功能。插件需要实现浏览器规定的一些函数,这些函数叫NPAPI.正是插件实现了这些函数才可以和浏览器交互。同时浏览器也为插件提供一些函数。在android平台下还有一些专有的函数。他们的函数名字都有约定。插件提供的方法以NPP_打头。浏览器提供的方法

  • python初级:基础知识-函数

    python初级:基础知识-函数

发表回复

您的电子邮箱地址不会被公开。

关注全栈程序员社区公众号