0
点赞
收藏
分享

微信扫一扫

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

Gaaidou 2021-09-30 阅读 42
Vue脚手架
sort方法接收一个函数作为参数,这里嵌套一层函数用来接收对象属性名,其他部分代码与正常使用sort方法相同.
//定义一个数组
var arr = [
    {
     id:85,
      name:"知识库2",
     logo:"iconfont iconic_services",
     type:"Site",
     visits:0,
  }, {
     id:86,
      name:"知识库",
     logo:"iconfont iconic_services",
     type:"Site",
     visits:3,
  },
];

function compare(property){
    return function(a,b){
        var value1 = a[property];
        var value2 = b[property];
        return value1 - value2;
    }
}
console.log(arr.sort(compare('visits')))
如何根据参数不同,来确定是升序排列,还是降序排序呢?

数组根据数组对象中的某个属性值进行排序的方法
* 使用例子:
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;
        }
    }
举报

相关推荐

0 条评论