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);
效果如下:
原文地址:https://www.cnblogs.com/ainyi/p/9651714.html
时间: 2024-10-25 08:00:52