js sort根据数组中对象的某个属性值进行排序

复制代码
sort⽅法接收⼀个函数作为参数,这⾥嵌套⼀层函数⽤来接收对象属性名,其他部分代码与正常使⽤sort⽅法相同.
var arr = [
    {name:'zopp',age:0},
    {name:'gpp',age:18},
    {name:'yjj',age:8}
];
function compare(property){
    return function(a,b){
        var value1 = a[property];
        var value2 = b[property];
        return value1 - value2;
    }
}
console.log(arr.sort(compare('age')))

// or  直接写是一样的
arr.sort((a,b)=>{
    return a.age -  b.age  // 从小到大排序  b.age - a.age 从大到小排序
  });
console.log(arr.sort(compare('age')))
复制代码

 

 

如何根据参数不同,来确定是升序排列,还是降序排序呢?

复制代码
/**数组根据数组对象中的某个属性值进⾏排序的⽅法
     * 使⽤例⼦:newArray.sort(sortBy('number',false)) //表⽰根据number属性降序排列;若第⼆个参数不传递,默认表⽰升序排序
     * @param attr 排序的属性如number属性
     * @param rev true表⽰升序排列,false降序排序
     * */
    sortBy: function(attr,rev){
        //第⼆个参数没有传递默认升序排列
        if(rev ==  undefined){
            rev = 1;
        }else{
            rev = (rev) ? 1 : -1;
        }
        return function(a,b){
            a = a[attr];
            b = b[attr];
            if(a < b){
                return rev * -1;
            }
            if(a > b){
                return rev * 1;
            }
            return 0;
        }
    }
复制代码

 

posted @   front-gl  阅读(366)  评论(0编辑  收藏  举报
相关博文:
阅读排行:
· 震惊!C++程序真的从main开始吗?99%的程序员都答错了
· 【硬核科普】Trae如何「偷看」你的代码?零基础破解AI编程运行原理
· 单元测试从入门到精通
· 上周热点回顾(3.3-3.9)
· winform 绘制太阳,地球,月球 运作规律
历史上的今天:
2020-05-16 JS 解决安卓手机输入框被软键盘遮住的问题
2020-05-16 vue项目keep-alive返回记住滚动条位置
2017-05-16 组件练习网址
2017-05-16 HTML DOM item() 方法
2017-05-16 php输出年份
2016-05-16 xampp
2016-05-16 浅谈javascript的Touch事件
点击右上角即可分享
微信分享提示