Array.prototype.sort()

Posted 疯狂的小标点

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了Array.prototype.sort()相关的知识,希望对你有一定的参考价值。

sort() 方法对数组的元素做原地的排序,并返回这个数组。默认按照字符串的Unicode码位点(code point)排序。

语法

arr.sort([compareFunction])

参数

compareFunction
可选。用来指定按某种顺序进行排列的函数。如果省略,元素按照转换为的字符串的诸个字符的Unicode位点进行排序。

详解

如果调用该方法时没有使用参数,将按字母顺序对数组中的元素进行排序,说得更精确点,是按照字符编码的顺序进行排序。要实现这一点,首先应把数组的元素都转换成字符串(如有必要),以便进行比较。

var fruit = [‘cherries‘, ‘apples‘, ‘bananas‘];
fruit.sort(); // [‘apples‘, ‘bananas‘, ‘cherries‘]

var scores = [1, 10, 2, 21]; 
scores.sort(); // [1, 10, 2, 21]
// Watch out that 10 comes before 2,
// because ‘10‘ comes before ‘2‘ in Unicode code point order.

var things = [‘word‘, ‘Word‘, ‘1 Word‘, ‘2 Words‘];
things.sort(); // [‘1 Word‘, ‘2 Words‘, ‘Word‘, ‘word‘]
// In Unicode, numbers come before upper case letters,
// which come before lower case letters.

  

如果想按照其他标准进行排序,就需要提供比较函数,该函数要比较两个值,然后返回一个用于说明这两个值的相对顺序的数字。比较函数应该具有两个参数 a 和 b,其返回值如下:

  • 若 a 小于 b,在排序后的数组中 a 应该出现在 b 之前,则返回一个小于 0 的值。
  • 若 a 等于 b,则返回 0。
  • 若 a 大于 b,则返回一个大于 0 的值。

比较器函数如下:

function compare(a, b) {
  if (a is less than b by some ordering criterion) {
    return -1;
  }
  if (a is greater than b by the ordering criterion) {
    return 1;
  }
  // a must be equal to b
  return 0;
}

希望比较数字而非字符串,比较函数可以简单的以 a 减 b,如下的函数将会将数组升序排列:

function compareNumbers(a, b) {
  return a - b;
}

以上为常见的sort()方法的使用,如不能满足您的需求,

请访问:https://developer.mozilla.org/zh-CN/docs/Web/javascript/Reference/Global_Objects/Array/sort  

  

 

以上是关于Array.prototype.sort()的主要内容,如果未能解决你的问题,请参考以下文章

Array.prototype.sort()

JS - Array.prototype.sort(compare)

数组的完全随机排列

Bubble Sort

js对数组中的数字排序

Write a merge sort program