vxe-table——实现切换页码时排序状态的回显问题(ant-design+elementUi中table排序不同时回显的bug)——js技能提升

之前写的后台管理系统,都是用的antd+elementtable组件中的【排序】问题是有一定的缺陷的。
想要实现的效果:
在这里插入图片描述

antv——table组件一次只支持一个参数的排序

如下图:
在这里插入图片描述
就算是可以自行将排序字段拼接到列表接口的入参中,页面中字段的排序也是只有一个的。不会同时显示排序的状态。比如像下面的
在这里插入图片描述

element——table组件一次只支持一个参数的排序

在这里插入图片描述
就连【default-sort】默认的排序参数,都只是一个对象,而非是一个数组。
在这里插入图片描述
没有办法实现我们想要的多个参数同时排序并且回显的效果。
在这里插入图片描述
前几天写的文章中的vxe-table组件可以实现这样的效果。

vxe-table组件实现多个参数同时排序的效果

感觉官网上有一部分内容还是不太好看的,只有真正用到了,才能明白其中的含义。

 <vxe-table
          size="small"
          border
          resizable
          ref="xTable1"
          id="toolbar_demo5"
          :custom-config="customConfig"
          show-overflow="tooltip"
          :sort-config="sortConfig"
          :row-config="rowConfig"
          :checkbox-config="checkboxConfig"
          :data="dataSource"
          :loading="loading"
          @checkbox-change="wipCheckboxChange"
          @checkbox-all="wipCheckboxAll"
          @sort-change="wipSortChange"
        >
        ....
       </vxe-table>

关于排序,这里面要用到的参数有:sortConfig sort-change

步骤1:sortConfig参数需要一开始mounted函数中就指定要排序的字段及方向

在这里插入图片描述
比如:我这边的要求是:将排序的内容缓存到本地,然后一进到这个页面就要显示上一次排序的效果。本次更改排序后再次缓存,一次循环。

所以在页面一开始mounted时,我就要取缓存的内容,并处理后放置到sortConfig

mounted(){
	let sort = localStorage.getItem('sort_arr');
    if (sort != undefined) {
      this.sort_arr = JSON.parse(sort);
      this.queryFrom.OrderBy = JSON.parse(sort).toString();
    }
    let sort_obj = JSON.parse(localStorage.getItem('sort_arr'));
    let defaultSort = [];
    if (sort_obj && sort_obj.length > 0) {
      sort_obj.forEach((item) => {
        let arr = item.split(' ');
        defaultSort.push({ field: arr[0], order: arr[1] });
      });
      this.sortConfig.defaultSort = defaultSort;
    }
}

步骤2:监听排序方法sort-change

 // 排序
wipSortChange({ column, field, order, sortBy, sortList }) {
  console.log(column, field, order, sortBy, sortList);
  if (sortList.length != 0) {
    let arr = sortList.map((v) => {
      return v.field + ' ' + v.order;
    });
    localStorage.setItem('sort_arr', JSON.stringify(arr));
  }
  let sort = localStorage.getItem('sort_arr');
  if (sort != undefined) {
    this.queryFrom.OrderBy = JSON.parse(sort).toString();
  }
  this.card_list_api();//这个是请求列表数据的接口
},

完成!!!

我看之前同事写的的代码:在切换分页的时候用到了this.$refs.xTable1.clearAll(),这个方法直接将排序的结果都清除了。这样是不对的。

页面选中的值,切换页码的时候没有回显的问题

可以在切换页码的时候,通过下面的代码来实现选中的回显:

if (this.selectedRows) {
  this.selectedRows.forEach((v) => {
    this.$refs.xTable1.setCheckboxRow(v, true);
  });
}

最近更新

  1. docker php8.1+nginx base 镜像 dockerfile 配置

    2024-07-23 05:18:04       67 阅读
  2. Could not load dynamic library ‘cudart64_100.dll‘

    2024-07-23 05:18:04       72 阅读
  3. 在Django里面运行非项目文件

    2024-07-23 05:18:04       58 阅读
  4. Python语言-面向对象

    2024-07-23 05:18:04       69 阅读

热门阅读

  1. vue中预览视频,word,pdf,xlsx

    2024-07-23 05:18:04       20 阅读
  2. service

    service

    2024-07-23 05:18:04      16 阅读
  3. vue3 页面引入组件

    2024-07-23 05:18:04       20 阅读
  4. NotebookApp Error unpacking user from cookie

    2024-07-23 05:18:04       19 阅读
  5. PHP基础语法(三)

    2024-07-23 05:18:04       23 阅读
  6. Linux中利用消息队列给两个程序切换显示到前台

    2024-07-23 05:18:04       21 阅读
  7. Python面试题:Python中的类型提示与静态类型检查

    2024-07-23 05:18:04       22 阅读
  8. 【架构专题】微服务架构

    2024-07-23 05:18:04       15 阅读
  9. 学术研究期刊

    2024-07-23 05:18:04       20 阅读