Javascript数组中已经存在两个可以直接用来排序的方法:reverse()和sort()方法。但是有时候这两个方法并不能够达到我们所期望的那个结果,比如:
var values=[0,1,5,10,15];
values.sort();
alert(values); // 0,1,10,15,5
很显然,这个结果并不满足我们的需求。这时,可以对此方法进行改进,让sort()方法接收一个比较函数作为参数,以便我们制定哪个值位于哪个值的前面。
这个比较函数接收两个参数,如果第一个参数应该位于第二个参数之前,则返回一个负数,如果两个参数相等,则返回0;如果第一个参数应该位于第二个参数之后则返回一个正数。如下:
function compare(value1,value2){
if(value1<value2){
return -1;
}else if(value1>value2){
return 1;
}else{
return 0;
}
}
这个函数可以适用于大多数数据类型,只要将其作为参数传递给sort()方法即可。如下面这个例子所示:
var values=[0,1,5,10,15];
values.sort(compare);
alert(values);// 0,1,5,10,15
这样产生的是一个升序的结果,如果想产生降序的结果,只要交换比较函数的返回的值就可以了。
修改如下:
function compare(value1,value2){
if(value1<value2){
return 1;
}else if(value1>value2){
return -1;
}else{
return 0;
}
}
var values=[0,1,5,10,15];
values.sort(compare);
alert(values);// 15,10,5,1,0
大家可以测试一下哦。
更多文章
欢迎访问 webpack 系列原创文章:
关注微信公众号
欢迎大家关注我的微信公众号阅读 更多 原创文章: