zoukankan      html  css  js  c++  java
  • Javascript重排序方法

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

    关注微信公众号

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

    just think and do it
  • 相关阅读:
    前端面试题
    js collection
    javascript变量声明提升(hoisting)
    css3动画
    神奇的meta
    wap站bug小结
    前端collection
    js拾遗
    prototype之初印象
    自定义scrollBottom的值
  • 原文地址:https://www.cnblogs.com/itdream/p/2534293.html
Copyright © 2011-2022 走看看