ant-design-vue中table组件多列排序

antD中table组件多列排序

  • 使用前注意
  • 实现效果图
  • 实现的功能点及相关代码
    • 1. 默认按某几个字段排序
    • 2. 点击排序按钮可同时对多个字段进行排序
    • 3. 点击重置按钮可恢复默认排序状态。
  • 功能实现完整的关键代码

使用前注意

先要确认你使用的antD版本是否支持多列排序,我这里版本是3.2.15,使用的vue3 + ts。

实现效果图

在这里插入图片描述

实现的功能点及相关代码

1. 默认按某几个字段排序

在声明table列时指定需要默认排序的列属性sortOrder(ascend | descend)。 sorter 对象中的multiple字段用于指定多列排序时的优先级。数值越大,优先级越高。这意味着你可以通过为不同的列设置不同的 multiple值来实现多列排序,并且控制它们的排序优先级。

const columns = ref([
    {
        title: 'ID',
        dataIndex: 'id',
        sorter: {
            multiple: 1,
        },
    },
    {
        title: '设备名称',
        dataIndex: 'name',
        sortOrder: 'descend',
        sorter: {
            multiple: 2,
        },
    },
    {
        title: '产品名称',
        dataIndex: 'productName',
    },
    {
        title: '创建时间',
        dataIndex: 'createTime',
        scopedSlots: true,
        width: 200,
        sortOrder: 'descend',
        sorter: {
            multiple: 3,
        },
    },
    {
        title: '状态',
        dataIndex: 'state',
        scopedSlots: true,
    },
    {
        title: '说明',
        dataIndex: 'describe',
    },
    {
        title: '操作',
        dataIndex: 'action',
        fixed: 'right',
        width: 200,
        scopedSlots: true,
    },
]);

2. 点击排序按钮可同时对多个字段进行排序

table组件绑定的方法`@change="onChange"`


/**
 * onChange方法实现:
 * 处理的都是columns这个数据源
 * 首先判断是单列还是多列排序:
 * 1. 若是多列同时排序,sorter为Array,map处理数据结构后,拿到需要排序数据与table列[columns]匹配,匹配到的给当前列字段的排序状态赋值
 * 2. 若是单列排序,sorter为Object,直接对匹配到的列赋值。
 * change方法会触发table的查询方法(给接口传的参数在table的查询方法中处理)
 */
const onChange = (pagination, filters, sorter, extra) => {
    if (Object.prototype.toString.call(sorter) === '[object Array]') {
        let sorterData = sorter.map((item) => {
            return {
                field: item.field,
                order: item.order,
            };
        });

        columns.value.map((column) => {
            column.sortOrder = undefined;
            sorterData.find((item) => {
                if (item.field === column.dataIndex) {
                    column.sortOrder = item.order;
                }
            });
        });
    } else {
        columns.value.forEach((item) => {
            item.sortOrder = undefined;
            if (item.dataIndex === sorter.field) {
                item.sortOrder = sorter.order;
            }
        });
    }
};

3. 点击重置按钮可恢复默认排序状态。

/**
 * 1. 查询和重置调用一个方法,在重置emit触发该方法时多传一个参数resetFlag为true
 * 2. 重置时将排序字段修改为需要默认排序字段,方法resetSort
 */
const handleSearch = (_params: any) => {
    // 对要排序的数据组合为后端接口想要的格式[{name: "XXX", order: 'XXX'}]
    let sortsParams = columns.value
        .filter((item) => item.sortOrder)
        .map((item) => ({
            name: item.dataIndex,
            order:
                item.sortOrder === 'descend'
                    ? 'desc'
                    : item.sortOrder === 'ascend'
                    ? 'asc'
                    : '',
        }));

    params.value = {
        sorts: sortsParams,
    };
    if (_params?.resetFlag) {
        resetSort();
    }
};

/**
 * 重置方法
 * 重置时匹配需要重置的列,将当前列sortOrder属性置为需要默认排序值(我这里默认按创建时间和名称倒序)
 */
const resetSort = () => {
    columns.value.forEach((column) => {
        column.sortOrder = undefined; // 取消所有字段排序
        if (column.dataIndex === 'createTime' || column.dataIndex === 'name') {
            column.sortOrder = 'descend';
        }
    });
};

功能实现完整的关键代码

<template>
    <!-- 上面查询区-代码省略 -->
    <!-- wTable为封装的table组件 -->
    <wTable
        ref="wTableRef"
        :columns="columns"
        :request="query"
        :params="params"
        @change="onChange"
    >
        <!-- 中间省略一些插槽代码 -->
        <!-- 
            上面属性的简单介绍:
            columns:展示的table列
            request: 查询/查询时table数据请求的接口
            params: 查询条件参数与排序字段相关参数
         -->
    </wTable>
</template>
<script setup lang="ts" name="Instance">
import { query } from '@/api/XXX';
const params = ref<Record<string, any>>({});
const columns = ref([
    {
        title: 'ID',
        dataIndex: 'id',
        sorter: {
            multiple: 1,
        },
    },
    {
        title: '设备名称',
        dataIndex: 'name',
        sortOrder: 'descend',
        sorter: {
            multiple: 2,
        },
    },
    {
        title: '产品名称',
        dataIndex: 'productName',
    },
    {
        title: '创建时间',
        dataIndex: 'createTime',
        scopedSlots: true,
        width: 200,
        sortOrder: 'descend',
        sorter: {
            multiple: 3,
        },
    },
    {
        title: '状态',
        dataIndex: 'state',
        scopedSlots: true,
    },
    {
        title: '说明',
        dataIndex: 'describe',
    },
    {
        title: '操作',
        dataIndex: 'action',
        fixed: 'right',
        width: 200,
        scopedSlots: true,
    },
]);

const onChange = (pagination, filters, sorter, extra) => {
    if (Object.prototype.toString.call(sorter) === '[object Array]') {
        let sorterData = sorter.map((item) => {
            return {
                field: item.field,
                order: item.order,
            };
        });

        columns.value.map((column) => {
            column.sortOrder = undefined;
            sorterData.find((item) => {
                if (item.field === column.dataIndex) {
                    column.sortOrder = item.order;
                }
            });
        });
    } else {
        columns.value.forEach((item) => {
            item.sortOrder = undefined;
            if (item.dataIndex === sorter.field) {
                item.sortOrder = sorter.order;
            }
        });
    }
};

const handleSearch = (_params: any) => {
    let sortsParams = columns.value
        .filter((item) => item.sortOrder)
        .map((item) => ({
            name: item.dataIndex,
            order:
                item.sortOrder === 'descend'
                    ? 'desc'
                    : item.sortOrder === 'ascend'
                    ? 'asc'
                    : '',
        }));

    params.value = {
        sorts: sortsParams,
    };
    if (_params?.resetFlag) {
        resetSort();
    }
};

const resetSort = () => {
    columns.value.forEach((column) => {
        column.sortOrder = undefined; 
        if (column.dataIndex === 'createTime' || column.dataIndex === 'name') {
            column.sortOrder = 'descend';
        }
    });
};
</script>

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:/a/921218.html

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

【LeetCode热题100】栈

这道题一共记录了关于栈的5道题目&#xff1a;删除字符串中所有相邻重复项、比较含退格的字符串、基本计算器II、字符串解码、验证栈序列。 class Solution { public:string removeDuplicates(string s) {string ret;for(auto c : s){if(ret.size() 0 || c ! ret.back()) ret …

IText创建加盖公章的pdf文件并生成压缩文件

第一、前言 此前已在文章&#xff1a;Java使用IText根据pdf模板创建pdf文件介绍了Itex的基本使用技巧&#xff0c;本篇以一个案例为基础&#xff0c;主要介绍IText根据pdf模板填充生成pdf文件&#xff0c;并生成压缩文件。 第二、案例 以下面pdf模板为例&#xff0c;生成一个p…

C语言——数组逐元素操作练习

定义一个能容纳10个元素的整形数组a&#xff0c;从键盘读取9个整数存放到前9个数组元素中。 一. 从键盘读取一个整数n和位置p(0<p<8)&#xff0c;插入n到数组a中&#xff0c;插入位置&#xff1a;下标p。要求插入点及后续的数组元素都要后移动。 代码如下&#xff1a; …

“iOS profile文件与私钥证书文件不匹配”总结打ipa包出现的问题

目录 文件和证书未加载或特殊字符问题 证书过期或Profile文件错误 确认开发者证书和私钥是否匹配 创建证书选择错误问题 申请苹果 AppId时勾选服务不全问题 ​总结 在上线ios平台的时候&#xff0c;在Hbuilder中打包遇见了问题&#xff0c;生成ipa文件时候&#xff0c;一…

网络安全之内网安全

下面给出了应对企业内网安全挑战的10种策略。这10种策略即是内网的防御策略&#xff0c;同时也是一个提高大型企业网络安全的策略。 1、注意内网安全与网络边界安全的不同 内网安全的威胁不同于网络边界的威胁。网络边界安全技术防范来自Internet上的攻击&#xff0c;主要是防…

项目总结模版

测试过程记录文档模版 我们经常测试经常需要做项目总结&#xff0c;所以小编这边就整理了一套项目总结模版&#xff0c;希望能够帮助到大家。 一、需求描述 对应指标&#xff1a;记录需求做的价值&#xff0c;用来评估后续项目上线后是否满足预期结果 1、需求文档 上传相关…

visual code:主题背景色的更换、常规设置

1、直接设置 进入界面->工具->主题->选择主题 2、常规设置 进入界面->工具->选项->环境->常规

低速接口项目之串口Uart开发(四)——UART串口实现FPGA内部AXILITE寄存器的读写控制

本节目录 一、设计背景 二、设计思路 三、逻辑设计框架 四、仿真验证 五、上板验证 六、往期文章链接本节内容 一、设计背景 通常&#xff0c;芯片手册或者IP都会提供一系列的用户寄存器以及相关的定义&#xff0c;用于软件开发人员进行控制底层硬件来调试&#xff0c;或封装…

python高阶技巧一

闭包 简单认识一下闭包 以下代码&#xff0c;内层inner函数不仅依赖于自身的参数b&#xff0c;还依赖于外层outer函数的参数a。inner就是一个闭包函数&#xff0c;既能访问外部变量&#xff0c;又保证外部变量不是全局的&#xff0c;不会被篡改掉&#xff0c;确保了外部变量的…

Redis最终篇分布式锁以及数据一致性

在前三篇我们几乎说完了Redis的所有的基础知识以及Redis怎么实现高可用性,那么在这一篇文章中的话我们主要就是说明如果我们使用Redis出现什么问题以及解决方案是什么,这个如果在未来的工作中也有可能会遇到,希望对看这篇博客的人有帮助,话不多说直接开干 一.Hotkey以及BigKey…

湘潭大学人工智能考试复习1(软件工程)

今年的试卷分值分布为&#xff1a; 选填40&#xff0c;两道计算题15x2 两道解答题15x2 复习重点&#xff1a; 1.人工智能学派派别 符号主义学派、连接主义学派、行为主义学派 各学派认知观&#xff1a; 符号主义&#xff08;逻辑主义、心理学派、计算机学派&#xff09;&am…

【蓝桥杯C/C++】深入解析I/O高效性能优化:std::ios::sync_with_stdio(false)

博客主页&#xff1a; [小ᶻZ࿆] 本文专栏: 蓝桥杯C/C 文章目录 &#x1f4af;前言&#x1f4af;C 语言与 C 语言的输入输出对比1.1 C 语言的输入输出1.2 C 语言的输入输出 &#x1f4af; std::ios::sync_with_stdio(false) 的作用与意义2.1 什么是 std::ios::sync_with_st…

GPT1.0 和 GPT2.0 的联系与区别

随着自然语言处理技术的飞速发展&#xff0c;OpenAI 提出的 GPT 系列模型成为了生成式预训练模型的代表。作为 GPT 系列的两代代表&#xff0c;GPT-1 和 GPT-2 虽然在架构上有着继承关系&#xff0c;但在设计理念和性能上有显著的改进。本文将从模型架构、参数规模、训练数据和…

嵌入式系统与OpenCV

目录 一、OpenCV 简介 二、嵌入式 OpenCV 的安装方法 1. Ubuntu 系统下的安装 2. 嵌入式 ARM 系统中的安装 3. Windows10 和树莓派系统下的安装 三、嵌入式 OpenCV 的性能优化 1. 介绍嵌入式平台上对 OpenCV 进行优化的必要性。 2. 利用嵌入式开发工具&#xff0c;如优…

戴尔 AI Factory 上的 Agentic RAG 搭载 NVIDIA 和 Elasticsearch 向量数据库

作者&#xff1a;来自 Elastic Hemant Malik, Dell Team 我们很高兴与戴尔合作撰写白皮书《戴尔 AI Factory with NVIDIA 上的 Agentic RAG》。白皮书是一份供开发人员参考的设计文档&#xff0c;概述了实施 Agentic 检索增强生成 (retrieval augmented generation - RAG) 应用…

特征交叉-MaskNet文章总结代码实现

MaskNet 这个模型是微博21年提出的&#xff0c;23年twitter(X)开源的推荐系统排序模块使用的backbone结构。 核心思想是认为DNN为主的特征交叉是addictive&#xff0c;交叉效率不高&#xff1b;所以设计了一种multiplicatvie的特征交叉 如何设计muliplicative特征交叉呢&#x…

GRU (门控循环单元 - 基于RNN - 简化LSTM又快又好 - 体现注意力的思想) + 代码实现 —— 笔记3.5《动手学深度学习》

目录 0. 前言 1. 门控隐状态 1.1 重置门和更新门 1.2 候选隐状态 1.3 隐状态 2. 从零开始实现 2.1 初始化模型参数 2.2 定义模型 2.3 训练与预测 3 简洁实现 4. 小结 0. 前言 课程全部代码&#xff08;pytorch版&#xff09;已上传到附件看懂上一篇RNN的所有细节&am…

Java 基于SpringBoot+vue框架的老年医疗保健网站

大家好&#xff0c;我是Java徐师兄&#xff0c;今天为大家带来的是Java Java 基于SpringBootvue框架的老年医疗保健网站。该系统采用 Java 语言开发&#xff0c;SpringBoot 框架&#xff0c;MySql 作为数据库&#xff0c;系统功能完善 &#xff0c;实用性强 &#xff0c;可供大…

JavaWeb-表单-07

表单标签 介绍 code: <!DOCTYPE html> <html lang"en"> <head><meta charset"UTF-8"> <meta name"viewport" content"widthdevice-width, initial-scale1.0"><title>HTML-表单</title> &…

计算机网络socket编程(4)_TCP socket API 详解

个人主页&#xff1a;C忠实粉丝 欢迎 点赞&#x1f44d; 收藏✨ 留言✉ 加关注&#x1f493;本文由 C忠实粉丝 原创 计算机网络socket编程(4)_TCP socket API 详解 收录于专栏【计算机网络】 本专栏旨在分享学习计算机网络的一点学习笔记&#xff0c;欢迎大家在评论区交流讨论&…