element-plus 官方表格排序问题

element-plus 官方API 默认表格排序存在问题,一个list 被多组排序

修改后:

javascript 复制代码
<template>
   <el-table
      :data="stateTable.table.data"
      @sort-change="(data) => handleSort(data, stateTable)"
    >
  </el-table>
<template>

<script setup>
import { reactive } from "vue";
import { copyTableData, handleSort } from "@/hooks/useSortTable.js";

let stateTable = reactive({
  table: {
    border: true,
    currentPage: 1,
    pageSize: 10,
    // 接口返回数据
    data: [],
    // 表头数据
    columns: [],
  },
});

const getTableData = async (data) => {
   copyTableData.value = [...stateTable.table.data]
};

getTableData()
</script>

useSortTable.js

javascript 复制代码
import { ref } from "vue";

export const copyTableData = ref([]);

export const sortByFieldDesc = (arr, field, order) => {
  arr.sort((a, b) => {
    const aValue = a?.[field];
    const bValue = b?.[field];
    let numA =
      typeof aValue === "string" && !isNaN(Number(aValue))
        ? Number(aValue)
        : aValue;
    let numB =
      typeof bValue === "string" && !isNaN(Number(bValue))
        ? Number(bValue)
        : bValue;
    if (
      typeof numA === "string" &&
      typeof numB === "string" &&
      !isNaN(Date.parse(numA)) &&
      !isNaN(Date.parse(numB))
    ) {
      // 如果是日期类型的字符串,则按照日期排序
      const dateA = new Date(numA);
      const dateB = new Date(numB);
      if (order === "descending") {
        return dateB - dateA;
      } else {
        return dateA - dateB;
      }
    } else {
      // 非日期类型,按照数字或其他类型的逻辑排序
      if (order === "descending") {
        return numB - numA;
      } else {
        return numA - numB;
      }
    }
  });
  return arr;
};

// 修改handleSort函数,使其接受stateTable作为参数
export const handleSort = (data, stateTable) => {
  const { prop, order } = data;
  let reserveData = copyTableData.value.filter(
    (item) =>
      item?.[prop] !== undefined &&
      item?.[prop] !== null &&
      item?.[prop] !== "-"
  );
  let filterData = copyTableData.value.filter(
    (item) =>
      item?.[prop] === undefined ||
      item?.[prop] === null ||
      item?.[prop] === "-"
  );
  if (order !== null) {
    sortByFieldDesc(reserveData, prop, order);
    stateTable.table.data = reserveData.concat(filterData);
  } else {
    stateTable.table.data = [...copyTableData.value];
  }
};
相关推荐
萌萌哒草头将军14 分钟前
绿联云 NAS 安装 AudioDock 详细教程
前端·docker·容器
计算机毕设VX:Fegn089527 分钟前
计算机毕业设计|基于springboot + vue宠物医院管理系统(源码+数据库+文档)
数据库·vue.js·spring boot·后端·课程设计
贺今宵32 分钟前
安装better-sqlite3报错electron-vite
javascript·sql·sqlite·sqlite3
GIS之路1 小时前
GIS 数据转换:使用 GDAL 将 GeoJSON 转换为 Shp 数据
前端
2501_944446001 小时前
Flutter&OpenHarmony文件夹管理功能实现
android·javascript·flutter
朴shu1 小时前
Luckysheet 远程搜索下拉 控件开发 : 揭秘二开全流程
前端
MediaTea2 小时前
Python:模块 __dict__ 详解
开发语言·前端·数据库·python
字节跳动开源3 小时前
Midscene v1.0 发布 - 视觉驱动,UI 自动化体验跃迁
前端·人工智能·客户端
光影少年3 小时前
三维前端需要会哪些东西
前端·webgl
王林不想说话4 小时前
React自定义Hooks
前端·react.js·typescript