zoukankan      html  css  js  c++  java
  • JS数组sort比较函数

    转载:http://www.cnblogs.com/ljchow/archive/2010/06/30/1768683.html

    我们知道,数组的sort方法可以对数组元素进行排序,默认是按ASCII字母表顺序排序。如果要根据其他的顺序排序就需要为sort方法提供一个比较函数作为参数。这里讲的就是如何写这个比较函数。

      譬如:

      var a=[1,5,3,7];

      a.sort(function(a, b) {

        return b-a

      });//从大到小排列

      那如果复杂点的顺序应该如何写这个比较函数呢。

      对于比较函数function f(a,b){...} ,若返回正数,则说明a和b需要交换,否则不交换。所以我们可以通通根据下面的格式去写比较函数:  

    1
    2
    3
    4
    5
    6
    7
    function f(a, b) {
        if (...) {
            return 1;
     
        }
        return -1;
    }

      然后,我们要做的就是写出if里面的条件,这个条件就是返回a、b需要交换的条件。譬如:对var a=["a","A","B","b"];进行不分大小写并从大到小排序,仅当a.toString().toLowerCase() < b.toString().toLowerCase()时,交换a、b,所以用此填充if条件即可。比较函数就是:

      function f(a, b) {
                if (a.toString().toLowerCase() < b.toString().toLowerCase()) {
                    return 1;

                }
                return -1;
            }

      再譬如:要使数组的元素按先奇数后偶数的顺序排列,则若需a、b交换,仅当满足a是偶数且b是奇数条件即可,再按从小到大排序,仅当满足a、b均是奇数或偶数且a>b时即可。如下:

    <script type="text/javascript">
    var a = [1, 7, 3, 9, 5, 6, 2, 8, 4];
    function f(a, b) {
    if (0 == a % 2 && 1 == b % 2) {
    return 1;
    }
    if ((1 == a % 2 && 1 == b % 2 || 0 == a % 2 && 0 == b % 2) && a > b) {
    return 1;
    }
    return -1;
    }
    alert(a.sort(f));
    </script>

  • 相关阅读:
    CentOS7安装Dnsmasq并更新最新版
    VMware vCenter Server Appliance(VCSA )6.7 部署,许可证破解
    vsphere6.7虚拟机与ESXI时间同步
    oracle使用存储过程返回数据集
    如何让CheckBoxList横着显示
    在oracle中创建自动增长字段
    oracle 11g安装客户端后使用ps/sql连接提示TNS适配器错误的解决办法
    myeclipse 网站项目部署失败
    Opera Dragonfly本地化
    ExtJs的fireEvent事件
  • 原文地址:https://www.cnblogs.com/BluceLee/p/8883675.html
Copyright © 2011-2022 走看看