数组多重排序

写法1

//直接在sort函数中自定义书写,适用性强

array.sort(function(ob1,ob2) {

    if(ob1.strength > ob2.strength) {

        return1;

    } elseif(ob1.strength < ob2.strength) {

        return-1;

    }

    // 当strength相等的时候会以name来进行比较if(ob1.name < ob2.name) {

        return-1;

    } elseif(ob1.name > ob2.name) {

        return1    } else{// nothing to split themreturn0;

    }

})

写法2

//比较使用一个通用函数,未必适用所有情况,字符串可以使用>比较,比较的是其字典序

cmp =function(a, b) {

    if(a > b)return+1;

    if(a < b)return-1;

    return0;

}

//直接使用原生的sort函数,当前面的比较为0时候,使用后面的比较

array.sort(function(a, b) {

    returncmp(a.strength,b.strength) || cmp(a.name,b.name)

})

写法3

//localeCompare比较会使用当地的字母比较规则,区别与>的unicode字典序

objects.sort(function (a, b) {

    returna.strength - b.strength || a.name.localeCompare(b.name);

});

写法4

使用thenBy.js


原文链接:https://www.cnblogs.com/mengff/p/7898160.html

出处: https://stackoverflow.com/questions/9175268/javascript-sort-function-sort-by-first-then-by-second

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
【社区内容提示】社区部分内容疑似由AI辅助生成,浏览时请结合常识与多方信息审慎甄别。
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

相关阅读更多精彩内容

友情链接更多精彩内容