javascript sort 函数用法
时间:2022-06-11
本文章向大家介绍javascript sort 函数用法,主要内容包括其使用实例、应用技巧、基本知识点总结和需要注意事项,具有一定的参考价值,需要的朋友可以参考一下。
sort 函数
简单的说,sort() 在没有参数时,返回的结果是按升序来排列的。即字符串的Unicode码位点(code point)排序
1 [5, 2, 4, 1, 3].sort();
2 // [1, 2, 3, 4, 5]
3
4 // 数字字符串也是从小到大
5 ['5', '2', '4', '1', '3'].sort();
6 // ['1', '2', '3', '4', '5']
如果指明了参数:compare(a, b) ,(a, b 是两个要比较的元素,a 在 b 前面)那么数组会按照该函数的返回值排序
- 如果 compare(a, b) 返回值 < 0 ,a 会被排列到 b 之前,即参数a, b的顺序保存原样;
- 如果 compare(a, b) 返回值 = 0 ,a 和 b 的相对位置不变。(ECMAScript 标准并不保证这一行为,而且也不是所有浏览器都会遵守)
- 如果 compare(a, b) 返回值 > 0 ,b 会被排列到 a 之前。即交换参数a, b的顺序
> 记:大于 0 交换顺序
题目
有如下数据:
1 [
2 {"name":"张三","class":2,"score":64},
3 {"name":"李四","class":1,"score":80},
4 {"name":"王五","class":1,"score":90},
5 {"name":"赵六","class":4,"score":94}
6 ]
实现:
* 按照 class 从小到大排列
* 如果 class 相同,则按照 score 从大到小排列
* 如果 class 和 score 都相同,则按照原顺序排列
1 function compare(name1, name2) {
2 // 这里的参数 a, b 是比较的第一个元素 a,第二个元素 b
3 return function (a, b) {
4 let fir1 = a[name1];
5 let sec1 = b[name1];
6 if (fir1 === sec1) {
7 let fir2 = a[name2];
8 let sec2 = b[name2];
9 if (fir2 === sec2) {
10 return 0; // 表示位置不变
11 } else {
12 return fir2 > sec2 ? -1 : 1; // 表示从大到小排序
13 }
14 } else {
15 return fir1 > sec1 ? 1 : -1; // 表示从小到大排序
16 }
17 }
18 }
19
20
21 function sortStudents(students) {
22 return students.sort(compare('class', 'score'));
23 }
24
25 let _students = JSON.parse(`[
26 {"name":"张三","class":2,"score":64},
27 {"name":"李四","class":1,"score":80},
28 {"name":"王五","class":1,"score":90},
29 {"name":"赵六","class":4,"score":94}]`);
30
31 let res = sortStudents(_students);
32 console.log(res);
效果如下:
- R语言进行中文分词,并对6W条微博聚类
- 只言片语分析datapump的工作原理(r2第18天)
- 开发 | TensorFlow全新的数据读取方式:Dataset API入门教程
- 用python实现支持向量机对婚介数据的用户配对预测
- SQL*Loader-805的解决(r2笔记36天)
- 用python实现决策树ID3算法,对隐形眼镜类型预测
- 用GA算法设计22个地点之间最短旅程-R语言实现
- 开发 | 谷歌发布TensorFlow 1.4版本:支持分布式训练,迎来三大新变化
- 创建用户时的密码校验问题(r2第34天)
- 巧用xmltype解析clob数据(r2笔记33天)
- R语言-中国各城市PM2.5数据间的相关分析
- 妹子如何运用R语言数据分析选择心仪的对象?
- 生产环境大型sql语句调优实战第一篇(二) (r2笔记32天)
- 生产环境大型sql语句调优实战第一篇(一) (r2笔记第31天)
- JavaScript 教程
- JavaScript 编辑工具
- JavaScript 与HTML
- JavaScript 与Java
- JavaScript 数据结构
- JavaScript 基本数据类型
- JavaScript 特殊数据类型
- JavaScript 运算符
- JavaScript typeof 运算符
- JavaScript 表达式
- JavaScript 类型转换
- JavaScript 基本语法
- JavaScript 注释
- Javascript 基本处理流程
- Javascript 选择结构
- Javascript if 语句
- Javascript if 语句的嵌套
- Javascript switch 语句
- Javascript 循环结构
- Javascript 循环结构实例
- Javascript 跳转语句
- Javascript 控制语句总结
- Javascript 函数介绍
- Javascript 函数的定义
- Javascript 函数调用
- Javascript 几种特殊的函数
- JavaScript 内置函数简介
- Javascript eval() 函数
- Javascript isFinite() 函数
- Javascript isNaN() 函数
- parseInt() 与 parseFloat()
- escape() 与 unescape()
- Javascript 字符串介绍
- Javascript length属性
- javascript 字符串函数
- Javascript 日期对象简介
- Javascript 日期对象用途
- Date 对象属性和方法
- Javascript 数组是什么
- Javascript 创建数组
- Javascript 数组赋值与取值
- Javascript 数组属性和方法