按照某个属性值排序,并将对象里的某个属性值当成键存的新对象{keys:{值}}中

原来的数组结构:
原图

最终效果:
在这里插入图片描述
使用了reduce(),forEach()方法

    let arr = [{ "key": "a", "value": 1, "sort": 2, }, {
      "key": "b", "value": 2, "sort": 0
    }, { "key": "c", "value": 3, "sort": 1 }, {
      "key": "d", "value": 4, "sort": 3
    }]

const convertArrtoObj = (arr, key) => {
      const initObj = {};
      return arr.reduce((obj, currVal) => {
        return {
          ...obj,
          [currVal.sort]: currVal
        }
      }, initObj);
    };
    const newnamesObj = convertArrtoObj(arr, 'sort');
    console.log(newnamesObj); //01.按sort排序到一个新对象中
    
    let res = {}    //声明新的对象
    Object.keys(newnamesObj).forEach(element => {
      console.log(element);
      let values1 = newnamesObj[element]
      res[values1.key] =  { 'value': values1.value, "sort": values1.sort } 
    });
    console.log(res);  //02.key为值创建一个新对象

注意事项:
有一个问题,chrome里的控制台打印展开后的顺序和未展开的不一致,导致问题的原因是:Chrome浏览器下创建的js对象数组会自动按照键排序,所以可以忽略,只关心第一行就行啦.
所以只看这个就行:
在这里插入图片描述

当然还有其他办法,这里只是一种.
关于控制台打印看这个链接javascript中的对象为什么会按照键来自动排序

  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值