根据对象某一属性进行排序

根据对象某一属性进行排序

var data = [
    { name: "tom" , age: 18 }, 
    { name: "jack" , age: 19 }, 
    { name: "mary" , age: 20 }
];

//定义一个比较器
function compare(propertyName) {
return function(object1, object2) {
  var value1 = object1[propertyName];
  var value2 = object2[propertyName];
  if (value2 < value1) {
    return 1;
  } else if (value2 > value1) {
    return -1;
  } else {
    return 0;
  }
}
}
//使用方法,根据age对数组的每个对象进行排序
data.sort(compare("age"));

console.log(data);

结果
这里写图片描述

sort的用法

sort() 方法可以接受一个 方法为参数 ,这个方法有两个参数。分别代表每次排序比较时的两个数组项。sort()排序时每次比较两个数组项都回执行这个参数,并把两个比较的数组项作为参数传递 给这个函数。当函数返回值为1的时候就交换两个数组项的顺序,否则就不交换。

var arr = [2,1,4,5,3] ;

arr.sort(function(a,b){ 
    if( a>b ){
        return 1 ;  //返回1表示正在比较的两个数需要交换位置
    }else if( a<b ){
        return -1 ; //返回1表示正在比较的两个数不需要交换位置
    }else{ 
        return 0 ;
    };
});

console.log( arr );   // [1, 2, 3, 4, 5]
在 JavaScript 中,将数组对象按照某属性进行排序可以使用以下几种方法: ### 自定义排序函数结合 `sort` 方法 如果需要根据对象的某个属性值进行排序,可以自定义排序函数并结合 `sort` 方法。以下是个通用的示例: ```javascript var list = [ { id: 23, number: 12 }, { id: 3, number: 3 }, { id: 13, number: 22 }, { id: 5, number: 30 }, { id: 1, number: 8 } ]; function sortord(property) { return function (a, b) { var value1 = a[property]; var value2 = b[property]; return value1 - value2; // 正序 // return value2 - value1; // 倒序 } } // 调用函数 console.log(list.sort(sortord("number")), &#39;排序结果&#39;); ``` 在这个示例中,`sortord` 函数接受属性名作为参数,返回个比较函数。这个比较函数会根据传入的属性名获取对象属性值,并根据这些值的大小关系返回个数字来决定元素的顺序 [^3]。 ### 另个自定义排序函数示例 ```javascript var newArray = [ { name: "aaa", value: 0 }, { name: "ddd", value: 3 }, { name: "bbb", value: 1 }, { name: "eee", value: 4 }, { name: "ccc", value: 2 } ]; function compare(property) { return function (a, b) { var value1 = a[property]; var value2 = b[property]; return value1 - value2; } } // 打印看结果 console.log(newArray.sort(compare("value"))); ``` 此示例中,`compare` 函数同样接受属性名作为参数,返回个比较函数,用于对数组对象按指定属性进行排序 [^4]。 ### 封装排序函数 ```javascript function objectArraySortByAtr(arr, property, isAsc = true) { return arr.sort((a, b) => { const value1 = a[property]; const value2 = b[property]; return isAsc ? value1 - value2 : value2 - value1; }); } const arr = [ { name: &#39;123&#39;, order: 3 }, { name: &#39;123&#39;, order: 1 }, { name: &#39;123&#39;, order: 8 }, { name: &#39;123&#39;, order: 2 }, { name: &#39;123&#39;, order: 6 }, { name: &#39;123&#39;, order: 9 }, { name: &#39;123&#39;, order: 0 } ]; objectArraySortByAtr(arr, &#39;order&#39;); // 按 order 属性正序排 objectArraySortByAtr(arr, &#39;order&#39;, false); // 按 order 属性倒序排 ``` 这里封装了 `objectArraySortByAtr` 函数,可以更方便地对数组对象按指定属性进行正序或倒序排序 [^5]。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值