javascript 学习笔记 【数组排序方法】

javascript 学习笔记 【数组排序方法】:

    数组中已经存在两个可以直接用来重排序的方法: reverse() 和 sort() 。reverse() 方法会反转数组项的顺序。

请看下面这个例子。

    var values = [1, 2, 3, 4, 5];

    values.reverse();

    alert(values); //5,4,3,2,1

    可见,即使例子中值的顺序没有问题,但 sort() 方法也会根据测试字符串的结果改变原来的顺序。因为数值 5 虽然小于 10,但在进行字符串比较时, “10” 则位于 “5” 的前面,于是数组的顺序就被修改了。不用说,这种排序方式在很多情况下都不是最佳方案。因此 sort() 方法可以接收一个比较函数作为参数,以便我们指定哪个值位于哪个值的前面。比较函数接收两个参数,如果第一个参数应该位于第二个之前则返回一个负数,如果两个参数相等则返回 0,如果第一个参数应该位于第二个之后则返回一个正数。以下就是一个简单的比较函数:

function compare(value1, value2) { if (value1 < value2) { return -1; } else if (value1 > value2) { return 1; } else { return 0; } }


对于数值类型或者其 valueOf() 方法会返回数值类型的对象类型,可以使用一个更简单的比较函数。这个函数只要用第二个值减第一个值即可。

> function compare(value1, value2){ return value2 - value1; } 由于比较函数通过返回一个小于零、等于零或大于零的值来影响排序结果,因此减法操作就可以适当地处理所有这些情况。

坚持原创技术分享,您的支持将鼓励我继续创作!
//