数组排序方法sort()
程序员文章站
2024-01-14 10:12:22
...
在默认情况下,sort()方法按升序排序数组项------即最小的值位于最前面,最大的值排在最后面。为了实现排序,sort()方法会调用toString()转型方法,然后比较得到的字符串。也就是说,即使数组中的每一项都是数值,sort()方法比较的也是字符串。
var values = [0,1,5,10,15];
values.sort();
alert(values);//0,1,10,15,5
可见,即使例子中的值的顺序没有问题,但sort()方法也会改变原来的顺序;
解决方法:sort()方法可以接收一个比较函数作为参数;
function compare(value1,value2){
if(value1 < value2){
return -1;
}else if(value1 > value2){
return 1;
}else{
return 0;
}
}
value.sort(compare);
由于比较函数通过返回一个小于零、等于零或大于零的值来影响排序结果,因此减法操作就可以处理所有这些情况;
更简洁的写法:
function compare(value1,value2){
return value1 - value2;
}
降序也是同样的方法,只需交换两个值的位置;
如果只是想翻转数组原来的顺序,使用reverse()方法。
上一篇: Collection集合的工具类