zoukankan      html  css  js  c++  java
  • Array.prototype.sort()对数组对象排序的方法

    Array.prototype.sort()方法接受一个参数——Function,Function会提供两个参数,分别是两个进行比较的元素,如果元素是String类型则通过Unicode code进行比较,如果是Number类型则比较值的大小。如果比较的函数中返回1则两个元素交换位置,0和-1不交换位置。

    var arr = [3, 5, 2, 1];
    // 从小到大排序
    arr.sort(function(a, b){
        return a > b ? 1 : -1;
    });
    // 得到的结果:[1, 2, 3, 5]

    如果是对一个数组对象进行排序,原理如下。

    var arr = [
        { a : 2, b : 3.2}, 
        { a : 3, b : 1.2}, 
        { a : 4, b : 2.2}, 
        { a : 6, b : 1.2}, 
        { a : 5, b : 3.2}
    ]
    /// 从小到大按属性b排序
    arr.sort(function(x, y){
        return x.b > y.b ? 1:-1;
    });

    x和y就是arr的一个元素,即一个对象,所以直接比较两个对象的属性即可。


    上面的例子中,最小的元素中有重复,如果需求是:先按b属性从小到大排序,如果最小中有重复则再按a属性排序,那应该怎么写呢?
    在排序的时候,先按b属性排序,如果x.b的大于y.b则将x移到y的右边,如果x.b等于y.b则再通过x.a和y.a进行比较,所以代码如下。

    arr.sort(function(x, y){
        if(x.b > y.b){
            return 1;
        }else if(x.b === y.b){
            return x.a > y.a ? 1 : -1;
        }else if(x.b < y.b){
            return -1;
        }
    });
  • 相关阅读:
    Linux基础命令---swapon
    Linux基础命令---fsck
    Linux基础命令---e2fsck
    Combination Sum
    Pow(x, n)
    Permutations
    Permutation Sequence
    Rotate List
    Unique Paths II
    Unique Paths
  • 原文地址:https://www.cnblogs.com/naokr/p/5424136.html
Copyright © 2011-2022 走看看