在javascript中的array中提供了sort()方法,但是该方法是按照数组中元素的升序排序,并且是根据数组元素的ascii码进行比较,这样往往不能得到自己想要的排序结果。比如:
var array = [1,5,28]; array.sort(); alert(array);
我们想要的排序后的结果是1,5,28。可是返回的结果却是1,28,5。因为检测到28中的2的ascii码比5的ascii码小,所以数组就把不再比较后面的内容,直接把28放在5的前面。
为了解决这个问题,现在我们来自己写个排序的方法代替默认的sort()。
function compare(num1,num2){
var tmp1 = parseInt(num1);
var tmp2 = parseInt(num2);
if(tmp1 < tmp2){
return -1;
}else if(tmp1==tmp2){
return 0;
}else{
return 1;
}
}
现在我们来调用该方法:
var array = [1,5,28]; array.sort(compare); alert(array);
运行后,会发现得到了我们想要的结果。
本文介绍JavaScript中默认数组排序方法的局限性,并提供一种自定义排序方法,通过比较两个数值大小实现正确升序排列。
1008

被折叠的 条评论
为什么被折叠?



