js常用的处理数据方法之对象篇

本文探讨了JavaScript中如何进行对象的扁平化处理,包括将嵌套的对象转换为单一层次的键值对结构,以简化数据操作。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

对象的扁平化处理

var obj = { 
    'A': 1, 
    'B.A': 2,
    'B.B': 3,
    'CC.D.A': 4,
    'CC.D.F': 5,
}
/**
 * 递归函数-处理数据
 * @param {*} str  对象的key值
 * @param {*} obj  已经存在的对象链
 * @param {*} value 到最后一个点时候赋的值
 */
var pinjie = function(str, obj,value) {
    if(str.includes('.')){
        let index = str.indexOf('.')
        if(str.slice(index + 1).includes('.')){
            // 记录当前的链子
            obj[str.slice(0,index)] = {...obj[str.slice(0,index)]}
            pinjie(str.slice(index + 1), obj[str.slice(0,index)], value)
        }else{
            obj[str.slice(0,index)] = {...obj[str.slice(0,index)]}
            obj[str.slice(0,index)][str.slice(index+1)] = value
        }
    }else{
        obj[str] = value
    }
}
var resaultObj = {}
for(let i in obj){
    pinjie(i, resaultObj, obj[i])
}
console.log(JSON.stringify(resaultObj))
// outPut {"A":1,"B":{"A":2,"B":3},"CC":{"D":{"A":4,"F":5}}}
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值