【js】数组对象根据key的值排序:


一、排序方法:
sortByQueryParams(property, asc = true) {//默认升序
  asc = asc == true ? -1 : 1  
  return function (value1, value2) {
     let a = value1[property]
     let b = value2[property]
     return a < b ? asc : a > b ? asc * -1 : 0
  }
},
二、使用:
#升序
this.dataList = this.dataList.sort(this.sortByQueryParams('sort'))
#或者
this.dataList = this.dataList.sort(this.sortByQueryParams('sort',true))

#降序
this.dataList = this.dataList.sort(this.sortByQueryParams('sort',false))
  • 1
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 1
    评论
实现 JavaScript 对象根据 key 进行排序需要依赖一些 JavaScript 高级函数,如 Object.keys()、Array.prototype.sort()、Array.prototype.reduce() 等。首先,使用 Object.keys() 方法取得对象的所有 keys,并存储在数组 keys 中;接着,通过调用 Array.prototype.sort()、Array.prototype.reduce() 方法结合自编 compareFunction 函数,根据 key 进行排序。 具体实现如下: const obj = { b: 2, a: 1, d: 4, c: 3 }; const keys = Object.keys(obj); // keys: ["b", "a", "d", "c"] keys.sort((a, b) => { if (a < b) return -1; if (a > b) return 1; return 0; }); const sortedObj = keys.reduce((acc, key) => { acc[key] = obj[key]; return acc; }, {}); // sortedObj: { a: 1, b: 2, c: 3, d: 4 } 通过 Object.keys() 方法,我们取得了 obj 对象的所有 key ,存储在数组 keys 中。接着,我们利用 Array.prototype.sort() 方法对 keys 数组进行排序,这里我们编写了一个简单的 compareFunction 函数,根据 key 进行排序。最后,我们使用 Array.prototype.reduce() 方法和一个空对象作为初始,遍历 keys 数组来创建一个新的对象 sortedObj,其中的 keys 按顺序排列。 这个过程可以很方便地用 ES6 的语法进行简化: const obj = { b: 2, a: 1, d: 4, c: 3 }; const sortedObj = Object.keys(obj) .sort() .reduce((acc, key) => { acc[key] = obj[key]; return acc; }, {}); // sortedObj: { a: 1, b: 2, c: 3, d: 4 } 这里我们使用了链式调用的方式,先进行数组排序,再使用 Array.prototype.reduce() 方法创建新的对象 sortedObj。这种方式代码更加简洁,但对于大型数据集可能会影响性能。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

Sun Peng

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值