查看: 1697|回复: 0

[JavaScript/JQuery] JavaScript中数组Array.sort()排序方法详解

发表于 2017-3-2 08:00:03

JavaScript中数组的sort()方法主要用于对数组的元素进行排序。其中,sort()方法有一个可选参数。但是,此参数必须是函数。 数组在调用sort()方法时,如果没有传参将按字母顺序(字符编码顺序)对数组中的元素进行排序,如果想按照其他标准进行排序,就需要进行传一个参数且为函数,该函数要比较两个值,并且会返回一个用于说明这两个值的相对顺序的数字。

1、对数字数组进行由小到大的顺序进行排序。

代码:

  1. var arr = [22,12,3,43,56,47,4];
  2. arr.sort();
  3. console.log(arr); // [12, 22, 3, 4, 43, 47, 56]
  4. arr.sort(function (m, n) {
  5. if (m < n) return -1
  6. else if (m > n) return 1
  7. else return 0
  8. });
  9. console.log(arr); // [3, 4, 12, 22, 43, 47, 56]
复制代码

2、对字符串数组执行不区分大小写的字母表排序。

代码:

  1. var arr = ['abc', 'Def', 'BoC', 'FED'];
  2. console.log(arr.sort()); // ["BoC", "Def", "FED", "abc"]
  3. console.log(arr.sort(function(s, t){
  4. var a = s.toLowerCase();
  5. var b = t.toLowerCase();
  6. if (a < b) return -1;
  7. if (a > b) return 1;
  8. return 0;
  9. })); // ["abc", "BoC", "Def", "FED"]
复制代码

3、对包含对象的数组排序,要求根据对象中的年龄进行由大到小的顺序排列

代码:

  1. var arr = [{'name': '张三', age: 26},{'name': '李四', age: 12},{'name': '王五', age: 37},{'name': '赵六', age: 4}];
  2. var objectArraySort = function (keyName) {
  3. return function (objectN, objectM) {
  4. var valueN = objectN[keyName]
  5. var valueM = objectM[keyName]
  6. if (valueN < valueM) return 1
  7. else if (valueN > valueM) return -1
  8. else return 0
  9. }
  10. }
  11. arr.sort(objectArraySort('age'))
  12. console.log(arr) // [{'name': '王五', age: 37},{'name': '张三', age: 26},{'name': '李四', age: 12},{'name': '赵六', age: 4}]
复制代码

 



回复

使用道具 举报