前端JS必用工具【js-tool-big-box】学习,根据属性对数组对象进行排序
创始人
2024-12-27 12:39:42
0

我们时常遇到这样的场景,服务端给返回的一些数据呢,是json对象是无序的,或者说返回了一个数组,但里面的数据,前端需要根据一些业务需求做排序。

这一小节呢,我们就说一下,利用 js-tool-big-box 工具库,根据一些属性对数据排序的方法。意思就是啊,我们一个json对象中,可能有年龄,有姓名,有时间等,我们根据这些属性,对数据从新排序。

1 安装js-tool-big-box工具库

 执行安装命令

npm install js-tool-big-box

引入 dataBox 对象,根据属性排序的方法被放到了这个对象下面

import { dataBox } from 'js-tool-big-box';

2 方法使用

我们预先准备一个数组数据:

const users = [       {"name": "小张伟", "age": 19, "dateTime": '2021-03-03 15:33:10'},       {"name": "张三", "age": 22, "dateTime": '2023-03-03 10:10:10'},       {"name": "李四", "age": 30, "dateTime": '2024-04-03 10:10:10'},       {"name": "阿斌", "age": 50, "dateTime": '2021-03-03 10:10:10'},       {"name": "曹小操", "age": 1300, "dateTime": '1021-05-08 10:10:10'}, ];

数据中有name,有age,有dateTime三个属性。 

2.1 根据数值型属性排序

从小到大的排序:

const ageResult1 = dataBox.sortByNumber(users, 'age'); console.log('age是数值型,从小到大,排序后的值为:', ageResult1);

展示效果:

 当然,你也可以让他从大到小的排列:

const ageResult2 = dataBox.sortByNumber(users, 'age', 1); console.log('age是数值型,从大到小,排序后的值为:', ageResult2);

2.2 数值型属性排序 - 方法总结

方法名返回值入参

sortByNumber

返回根据第二个入参排序后的数组

第一个参数必填,表示需要被排序的json型数组;

第二个参数必填,表示需要用哪个属性排序,最好传入的属性的属性值为数值型;

第三个参数非必填,表示是否需要倒序排序

2.3 中文按字母顺序排序

从A到Z的排序:

const nameResult1 = dataBox.sortByletter(users, 'name'); console.log('比如name,我们按照字母顺序排序后为:', nameResult1);

从Z到A的排序: 

const nameResult2 = dataBox.sortByletter(users, 'name', 1); console.log('比如name,我们按照字母顺序倒序排序后为:', nameResult2);

2.4 中文按字母顺序排序 - 方法总结 

方法名返回值入参

sortByletter

返回根据第二个入参排序后的数组

第一个入参必填,表示需要被排序的数组;

第二个入参必填,表示需要用哪个属性排序,这个你需要提前甄别,你传入的属性值是否为中文;

第三个参数非必填,表示是否需要倒序排序

2.5 按时间排序 

从早到晚的排序:

const timeResult1 = dataBox.sortByTime(users, 'dateTime'); console.log('以时间从早到晚排序后的值为:', timeResult1);

从晚到早的排序:

const timeResult2 = dataBox.sortByTime(users, 'dateTime', 1); console.log('以时间从晚到早排序后的值为:', timeResult2);

2.6 按时间排序 - 方法总结 

方法名返回值入参

sortByTime

返回根据第二个入参排序后的数组

第一个入参必填,表示需要被排序的数组;

第二个入参必填,表示需要用哪个属性排序,传入的属性的属性值最好是时间类型;

第三个参数非必填,表示是否需要倒序排序

------------------------------------------

这是git仓库地址:js-tool-big-box仓库地址 

相关内容

热门资讯

烘培辅助!小程序广东雀神智能插... 烘培辅助!小程序广东雀神智能插件免费(辅助)其实是真的有辅助攻略(哔哩哔哩);1、小程序广东雀神智能...
法子辅助!蛮王大厅辅助教程(辅... 法子辅助!蛮王大厅辅助教程(辅助)果然真的有辅助教程(哔哩哔哩)蛮王大厅辅助教程辅助器是一种具有地方...
窍要辅助!桂林字牌黑科技(辅助... 窍要辅助!桂林字牌黑科技(辅助)本来一直总是有辅助工具(哔哩哔哩)1)桂林字牌黑科技免费钻石:进一步...
模板辅助!微信海盗来了辅助工具... 模板辅助!微信海盗来了辅助工具(辅助)一贯真的是有辅助脚本(哔哩哔哩)1、让任何用户在无需微信海盗来...
教材辅助!四川麻将血战到底辅助... 教材辅助!四川麻将血战到底辅助器(辅助)好像有辅助app(哔哩哔哩)1、下载好四川麻将血战到底辅助器...
教程书辅助!白银胡乐辅助脚本最... 教程书辅助!白银胡乐辅助脚本最新版安装方法(辅助)一直是真的有辅助攻略(哔哩哔哩)1、下载好白银胡乐...
操作辅助!哈狗脚本辅助(辅助)... 操作辅助!哈狗脚本辅助(辅助)切实一直都是有辅助教程(哔哩哔哩)1、金币登录送、破产送、升级送、活动...
烘培辅助!福建大菠萝辅助透视(... 烘培辅助!福建大菠萝辅助透视(辅助)本来真的是有辅助app(哔哩哔哩)暗藏猫腻,小编详细说明福建大菠...
大纲辅助!玫瑰大厅辅助(辅助)... 大纲辅助!玫瑰大厅辅助(辅助)果然一直总是有辅助技巧(哔哩哔哩)大纲辅助!玫瑰大厅辅助(辅助)果然一...
步骤辅助!创思维激K辅助器开挂... 步骤辅助!创思维激K辅助器开挂(辅助)真是是真的有辅助教程(哔哩哔哩)1、打开软件启动之后找到中间准...