【js小技】合并数组对象元素中的key与value

整个标题就很莫名其妙(bushi!

整理的数组如下(处处彰显菜鸡就是了இ௰இ)

let objArr = [{ctl:'1dtl',dtl:'2'},
            {ctl:'3dtl',dtl:'4'},
            {ctl:'11dtl',dtl:'2'},
            {ctl:'11dtl',dtl:'12'},
            {ctl:'13dtl',dtl:'4'},
            {ctl:'13dtl',dtl:'14'}];

目标是根据数组中的对象元素相同的 dtl 值 ,把 ctl 对应的值合并起来 ,并且相同的key值不能被覆盖❗(整个描述有被乱到/(ㄒoㄒ)/~~)简言之,要实现的数据形式如下:

let resultObj = {2dtl:'1, 11', 
        4dtl:'3, 13', 
        12dtl:'11', 
        14dtl:'13'};

由于最开始整理的objArr过于混乱,所以不得不愚钝且煞费苦心写一些无中生有的转换方法(其实是透露着一些智慧结晶的精妙方法👏

方法一:


    let resultMap = {};
    objArr.forEach(obj => {
    let ctl = obj.ctl.substring(0, obj.ctl.indexOf("d"));
    let objCtl = resultMap[obj.dtl + "dtl"];
    if (!objCtl) {
       resultMap[obj.dtl + "dtl"] = ctl;
    } else {
       resultMap[obj.dtl + "dtl"] = objCtl + ',' + ctl;
    }
    });

方法二:


        let tempArr = [];
        let afterData = []; 
        for (let i = 0; i < objArr.length; i++) {
            if (tempArr.indexOf(objArr[i].dtl) === -1) {
                afterData.push({
                    dtl: objArr[i].dtl,
                    ctl: [objArr[i].ctl],
                });
                tempArr.push(objArr[i].dtl);
            } else {
                for (let j = 0; j < afterData.length; j++) {
                    if (afterData[j].dtl == objArr[i].dtl) {
                        afterData[j].ctl.push(objArr[i].ctl);
                        break;
                    }
                }
            }
        }
        afterData.map((item) => {
            item.ctl= item.ctl.join(",");
        });               // 循环afterData数组重新合并
        let resultObj = {};
        afterData.forEach(i=>{
            resultObj[i.dtl+'dtl'] = i.ctl;
        });
        for(let k in resultObj){
            resultObj[k] = resultObj[k].replace(/dtl/g,"");
        }

半写半忘,在此终于大功告成😉

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值