注册
web

改写el-table表格排序, 支持多列排序远程排序!!!

改写el-table的默认排序


提示:在el-table封装的表格基础上改写排序方法




前言


我们在做表格的时候经常会遇到表头有一个排序的icon 用来对数据进行, el-table有自己的排序方法, 如下:



在列中设置sortable属性即可实现以该列为基准的排序,接受一个Boolean,默认为false。





一、el-table支持调接口排序吗?


el-table默认的排序支持从接口获取排序的数据



sortable: 对应列是否可以排序,如果设置为 custom,则代表用户希望远程排序,需要监听 Table 的 sort-change 事件



二、el-table支持多列排序吗?


默认的排序很简单, 加一个参数就可以了, 而且会自动根据数据进行排序, 但是我们会发现, 默认的排序只支持一列进行排序, 当我们排过一列之后在点击另一列的排序图标, 之前的排序就会消失😨.


三、如何实现多列远程排序?



  1. 自己写一个组件插入到表头的位置实现排序
  2. 根据el-table已有的属性以及抛出的方法实现多列排序

如果手动封装一个组件肯定能实现, 但是比较麻烦, 所以就研究了el-table相关了一些属性和方法, 思路如下:



header-cell-class-name: 表头单元格的 className 的回调方法,也可以使用字符串为所有表头单元格设置一个固定的className



在点击表头的时候排序的列以及是升降序保存到一个数组对象ordersList里, 然后通过header-cell-class-name属性设置选中的样式.


四、核心代码


	data: {
return {
ordersList: [],
}
}
// 点击表头
handleHeaderCLick(column){
if (column.sortable !== 'custom') {
return
}
if (!column.multiOrder) {
column.multiOrder = 'descending'
} else if (column.multiOrder === 'descending') {
column.multiOrder = 'ascending'
} else {
column.multiOrder = ''
}
this.handleOrderChange(column.property, column.multiOrder)

},
handleOrderChange (orderColumn, orderState) {
let result = this.ordersList.find(e => e.orderColumn === orderColumn)
if (result) {
result.orderState = orderState
} else {
this.ordersList.push({
orderColumn: orderColumn,
orderState: orderState,
})
}
// 调接口查询,在传参的时候把ordersList进行处理成后端想要的格式(这里是把数据抛出, 外部调用组件的地方处理)
this.sendInfo(this.ordersList, 'sort-change')
},
// 上面缺点是只能通过点击表头切换排序状态,点击小三角排序不会触发,处理sort-change事件和点击表头一样
sortChange({column}) {
// 有些列不需要排序,提前返回
if (column.sortable !== 'custom') {
return
}
if (!column.multiOrder) {
column.multiOrder = 'descending'
} else if (column.multiOrder === 'descending') {
column.multiOrder = 'ascending'
} else {
column.multiOrder = ''
}
this.handleOrderChange(column.property, column.multiOrder)
},
// 设置列的排序为我们自定义的排序
handleHeaderClass({ column }) {
column.order = column.multiOrder
}

这样外部拿到的就是一个所有排序的数组, 包括prop以及当前列的排序规则(ascending/descending/null), 将其处理成正确的入参格式即可.




在这里插入图片描述

在这里插入图片描述


如此, 就实现了多列远程排序, 欢迎大家一起讨论学习😊~


作者:小星星__
来源:juejin.cn/post/7238479015723089980

0 个评论

要回复文章请先登录注册