JavaScript中陣列Array.sort()排序方法詳解

風靈使發表於2018-05-26

JavaScript中陣列的sort()方法主要用於對陣列的元素進行排序。其中,sort()方法有一個可選引數。但是,此引數必須是函式。 陣列在呼叫sort()方法時,如果沒有傳參將按字母順序(字元編碼順序)對陣列中的元素進行排序,如果想按照其他標準進行排序,就需要進行傳一個引數且為函式,該函式要比較兩個值,並且會返回一個用於說明這兩個值的相對順序的數字。

1、對數字陣列進行由小到大的順序進行排序。

程式碼:

var arr = [22,12,3,43,56,47,4];
arr.sort();
console.log(arr); // [12, 22, 3, 4, 43, 47, 56]
arr.sort(function (m, n) {
 if (m < n) return -1
 else if (m > n) return 1
 else return 0
});
console.log(arr); // [3, 4, 12, 22, 43, 47, 56]

2、對字串陣列執行不區分大小寫的字母表排序。

程式碼:

var arr = ['abc', 'Def', 'BoC', 'FED'];
console.log(arr.sort()); // ["BoC", "Def", "FED", "abc"]
console.log(arr.sort(function(s, t){
 var a = s.toLowerCase();
 var b = t.toLowerCase();
 if (a < b) return -1;
 if (a > b) return 1;
 return 0;
})); // ["abc", "BoC", "Def", "FED"]

3、對包含物件的陣列排序,要求根據物件中的年齡進行由大到小的順序排列

程式碼:

var arr = [{'name': '張三', age: 26},{'name': '李四', age: 12},{'name': '王五', age: 37},{'name': '趙六', age: 4}];
var objectArraySort = function (keyName) {
 return function (objectN, objectM) {
  var valueN = objectN[keyName]
  var valueM = objectM[keyName]
  if (valueN < valueM) return 1
  else if (valueN > valueM) return -1
  else return 0
 }
}
arr.sort(objectArraySort('age'))
console.log(arr) // [{'name': '王五', age: 37},{'name': '張三', age: 26},{'name': '李四', age: 12},{'name': '趙六', age: 4}]

相關文章