el-table表格排序(多列排序和远程排序)

 更新时间:2023年05月30日 11:02:55   作者:小星星__  
本文主要介绍了el-table表格排序(多列排序和远程排序),文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧

前言

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

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

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

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

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

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

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

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

  • 自己写一个组件插入到表头的位置实现排序
  • 根据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), 将其处理成正确的入参格式即可.

到此这篇关于el-table表格排序(多列排序和远程排序)的文章就介绍到这了,更多相关el-table表格排序内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

相关文章

  • vue.config.js中配置configureWebpack和chainWebpack以及一些常用的配置

    vue.config.js中配置configureWebpack和chainWebpack以及一些常用的配置

    configureWebpack和chainWebpack都是Vue CLI中用于修改Webpack配置的工具,configureWebpack可以通过对象或函数修改配置,简单直接;chainWebpack则使用WebpackChainAPI,适合复杂配置,两者可以结合使用,以达到更精细的配置需求,帮助开发者优化项目构建
    2024-10-10
  • Vue+element自定义指令如何实现表格横向拖拽

    Vue+element自定义指令如何实现表格横向拖拽

    这篇文章主要介绍了Vue+element自定义指令如何实现表格横向拖拽,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
    2022-10-10
  • vue车牌搜索组件使用方法详解

    vue车牌搜索组件使用方法详解

    这篇文章主要为大家详细介绍了vue车牌搜索组件的使用方法,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2021-09-09
  • Vue.js中用v-bind绑定class的注意事项

    Vue.js中用v-bind绑定class的注意事项

    关于数据绑定一个常见需求就是操作元素的class列表和它的内联样式。因为它们都是属性,我们可以用 v-bind 处理它们,但是使用v-bind绑定class的时候我们要有一些注意事项,下面这篇文章就给大家分享了下要注意的方面,希望能对大家有所帮助,下面来一起看看吧。
    2016-12-12
  • vue教程之toast弹框全局调用示例详解

    vue教程之toast弹框全局调用示例详解

    这篇文章主要为大家详细介绍了vue教程之toast弹框全局调用示例,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2017-08-08
  • vue具名插槽的基本使用实例

    vue具名插槽的基本使用实例

    Vue 中的插槽在开发组件的过程中其实是非常重要并且好用的。下面这篇文章主要给大家介绍了关于vue具名插槽基本使用的相关资料,需要的朋友可以参考下
    2021-05-05
  • Vue实现大屏页面的屏幕自适应

    Vue实现大屏页面的屏幕自适应

    这篇文章主要为大家详细介绍了Vue实现大屏页面的屏幕自适应,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2021-10-10
  • vue第三方库中存在扩展运算符报错问题的解决方案

    vue第三方库中存在扩展运算符报错问题的解决方案

    这篇文章主要介绍了vue第三方库中存在扩展运算符报错问题,本文给大家分享解决方案,通过结合实例代码给大家介绍的非常详细,需要的朋友可以参考下
    2022-07-07
  • 详解vue.js的devtools安装

    详解vue.js的devtools安装

    本篇文章主要介绍了详解vue.js的devtools安装 ,小编觉得挺不错的,现在分享给大家,也给大家做个参考。一起跟随小编过来看看吧
    2017-05-05
  • 通过fastclick源码分析彻底解决tap“点透”

    通过fastclick源码分析彻底解决tap“点透”

    这篇文章主要介绍了通过fastclick源码分析彻底解决tap“点透”问题的知识内容,有兴趣的朋友学习一下吧。
    2017-12-12

最新评论