1. 程式人生 > >javascript sort 函數用法

javascript sort 函數用法

=== core 瀏覽器 沒有 這一 字符 int 相同 題目

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);

效果如下:

技術分享圖片

javascript sort 函數用法