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 系列原创文章:

关注微信公众号

欢迎大家关注我的微信公众号阅读 更多 原创文章:

 posted on 2012-06-04 10:56  全栈在路上  阅读(589)  评论(0编辑  收藏  举报