项目经验】:elementui表格中数字汉字排序问题

本文涉及的产品
对象存储 OSS,OSS 加速器 50 GB 1个月
简介: elementui表格中数字汉字排序问题

一.需求

表格中数字汉字排序,数字按大小排列,汉字按拼音首字母(A-Z)排序。

二.用到的方法

第一步:把el-table-column上加上sortable="custom"

<el-table-columnprop="date"label="序号"sortable="custom"width="180"></el-table-column>

方法详细介绍:

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

第二步:在el-table绑定事件sort-change

<el-table:data="tableData"style="width: 100%"@sort-change="sort_change">

方法详细介绍:

sort-change 当表格的排序条件发生变化的时候会触发该事件 { column, prop, order }

第三步:实现功能(代码)

sort_change ({ column, prop, order }) {
letfieldname=prop;
letsortType=order;
if (fieldname=='date') {
// 数字排序this.getNums(fieldname, sortType)
            }
if (fieldname=='name') {
// 汉字首字母排序this.tableData.sort(this.compare(fieldname, sortType));
            }
        },
// 数字排序getNums (fieldname, sortType) {
if (sortType==="ascending") {
this.tableData=this.tableData.sort((a, b) =>b[fieldname] -a[fieldname]);
// console.log(this.tableData);            } elseif (sortType==="descending") {
this.tableData=this.tableData.sort((a, b) =>a[fieldname] -b[fieldname]);
            }
        },
// 汉字首字母排序compare (propertyName, sort) {
returnfunction (obj1, obj2) {
varvalue1=obj1[propertyName];
varvalue2=obj2[propertyName];
if (typeofvalue1==="string"&&typeofvalue2==="string") {
constres=value1.localeCompare(value2, 'zh');
returnsort==="ascending"?res : -res;
                } else {
if (value1<=value2) {
returnsort==="ascending"?-1 : 1;
                    } elseif (value1>value2) {
returnsort==="ascending"?1 : -1;
                    }
                }
            }
        }

三.字符串方法localeCompare()

概念:localeCompare() 方法用于比较两个字符串,并根据本地排序规则确定这两个字符串的顺序。这可以用于排序,例如在表格中按字母顺序排列行。

语法:string.localeCompare(compareString[, locales[, options]])

参数说明:

compareString:必需。要与调用字符串进行比较的字符串。

locales:可选。一个字符串数组,用于指定一种或多种区域设置代码。

options:可选。一个包含属性的对象,用于控制比较的各方面。

注意事项:

1、localeCompare() 方法是大小写敏感的。例如,"a" 和 "A" 是不同的字符。

2、localeCompare() 方法也是重音符号敏感的。例如,"é" 和 "è" 是不同的字符。

3、localeCompare() 方法的默认区域设置是当前系统的区域设置。

4、localeCompare() 方法返回的数字取决于本地排序规则。不同的语言和不同的区域设置可能会有不同的排序规则。

5、localeCompare() 方法不会更改原始字符串。它只是返回一个数字。

常用场景:汉字排序

四.总结

  1. 这里面相当于用了一个表格自定义排序方法,这个点是我们该考虑的,这里还可以用sort-method。这个方法是需要在每列都加的,我当时做的是动态添加表头的需求,sort-method就不好实现。
  2. 想用sort-change方法来自定义排序方法一定要sortable="custom";如果sortable="true",就代表你使用的默认排序。只有order=null时才会触发你自定义的方法。

五.源码(可直接复制跑起来)

<template><divclass="about"><el-table :data="tableData"style="width: 100%"@sort-change="sort_change"><el-table-columnprop="date"label="序号"sortable="custom"width="180"></el-table-column><el-table-columnprop="name"label="姓名"sortable="custom"width="180"></el-table-column></el-table></div></template><script>exportdefault {
name: 'WorkspaceJsonAboutView',
data () {
return {
tableData: [{
date: '1',
name: '田禹',
            }, {
date: '2',
name: '康康',
            }, {
date: '3',
name: '振洋',
            }, {
date: '4',
name: '根宝',
            }, {
date: '5',
name: '彤彤',
            }, {
date: '6',
name: '建鹏',
            }, {
date: '7',
name: '文文',
            }, {
date: '8',
name: '铖',
            }
            ],
        };
    },
mounted () {
    },
methods: {
sort_change ({ column, prop, order }) {
letfieldname=prop;
letsortType=order;
if (fieldname=='date') {
// 数字排序this.getNums(fieldname, sortType)
            }
if (fieldname=='name') {
// 汉字首字母排序this.tableData.sort(this.compare(fieldname, sortType));
            }
        },
// 数字排序getNums (fieldname, sortType) {
if (sortType==="ascending") {
this.tableData=this.tableData.sort((a, b) =>b[fieldname] -a[fieldname]);
// console.log(this.tableData);            } elseif (sortType==="descending") {
this.tableData=this.tableData.sort((a, b) =>a[fieldname] -b[fieldname]);
            }
        },
// 汉字首字母排序compare (propertyName, sort) {
returnfunction (obj1, obj2) {
varvalue1=obj1[propertyName];
varvalue2=obj2[propertyName];
if (typeofvalue1==="string"&&typeofvalue2==="string") {
constres=value1.localeCompare(value2, 'zh');
returnsort==="ascending"?res : -res;
                } else {
if (value1<=value2) {
returnsort==="ascending"?-1 : 1;
                    } elseif (value1>value2) {
returnsort==="ascending"?1 : -1;
                    }
                }
            }
        }
    },
};
</script><stylelang="less"scoped>.about {
width: 100%;
height: 100%;
background: yellowgreen;
display: flex;
justify-content: center;
align-items: center;
    .tableDiv {
width: 800px;
height: 100%;
    }
}
.el-table ::webkit-scrollbar {
display: block;
height: 938px;
width: 6px;
}
.el-table ::webkit-scrollbar-thumb {
box-shadow: inset000pxwhite;
-webkit-box-shadow: inset000pxwhite;
background: rgba(64, 158, 255, 0.6);
border-radius: 4px;
}
.el-table ::-webkit-scrollbar-track {
background: #424f6a;}
</style>
相关文章
|
缓存
若依 this.$router.push 同地址不同参,页面不刷新问题
若依 this.$router.push 同地址不同参,页面不刷新问题
1752 0
|
11月前
|
前端开发 API
el-table实现动态数据的实时排序,一篇文章讲清楚elementui的表格排序功能,利用@sort-change实现动态数据排序,el-table排序方法,el-table可变数据的动态排序
博客不应该只有代码和解决方案,重点应该在于给出解决方案的同时分享思维模式,只有思维才能可持续地解决问题,只有思维才是真正值得学习和分享的核心要素。如果这篇博客能给您带来一点帮助,麻烦您点个赞支持一下,还可以收藏起来以备不时之需,有疑问和错误欢迎在评论区指出~
element-ui table排序sortable三种状态,怎么去掉默认状态
在 element-ui 中,也定义了 sort-orders 有三种状态: ascending、descending、null,这三种状态形成一个循环切换。
3570 0
|
JSON 小程序 JavaScript
|
JavaScript 安全 API
iframe嵌入页面实现免登录思路(以vue为例)
通过上述步骤,可以在Vue.js项目中通过 `iframe`实现不同应用间的免登录功能。利用Token传递和消息传递机制,可以确保安全、高效地在主应用和子应用间共享登录状态。这种方法在实际项目中具有广泛的应用前景,能够显著提升用户体验。
1687 9
|
数据采集 API 开发者
拼多多API接口怎么申请
拼多多API接口申请步骤简述:首先访问拼多多开放平台并注册账号,选择开发者类型并填写资料,审核通过后创建应用并申请API接口权限,等待审核结果,获取API密钥等信息。完成后,即可使用拼多多API接口进行开发,注意遵守相关规定。
|
JavaScript 前端开发 搜索推荐
ECharts词云图(案例一)+配置项详解
ECharts,百度的JavaScript图表库,支持词云图(自5.0版起),借助`echarts-wordcloud`插件。配置词云图涉及`tooltip`(如显示、颜色、边框等)和`series`(类型、形状、大小范围等)。示例代码展示了如何在HTML中引入依赖并配置词云图,包括数据、形状、大小、颜色等。完整代码和依赖可下载。调整这些配置可创建个性化词云图。参阅官方文档获取不同版本详情。
5465 4
 ECharts词云图(案例一)+配置项详解
Echarts各类图表常用配置项说明,附示例代码
Echarts各类图表常用配置项说明,附示例代码
|
前端开发
如何实现CSS中flex布局最后一行左对齐?
前言 flex布局目前已经非常流行了,它基本上可以完成大部分的布局需求。早一些的float布局、表格布局等等便没有那么受欢迎了。但是任何事物都不是完美的,flex布局也一样,它也有瑕疵,就比如我们今天所要讲的flex布局中最后一行对齐问题。
2966 0
如何实现CSS中flex布局最后一行左对齐?