自定义flatten方法实现对象扁平化

本文探讨如何在JavaScript中实现一个自定义的flatten方法,将多层次的对象结构转换为单层扁平结构,方便数据处理。通过递归遍历对象属性,将嵌套的属性合并到一个平铺的对象中。
function flatten(obj) {
        let result = {};
        let process = (key, value) => {
            // 首先判断是基础数据类型还是引用数据类型
            if (Object(value) !== value) {
                // 基础数据类型
                if (key) {
                    result[key] = value;
                }
            } else if (Array.isArray(value)) {
                for (let i = 0; i < value.length; i++) {
                    process(`${key}[${i}]`, value[i])
                }
                if (value.length === 0) {
                    result[key] = [];
                }
            } else {
                let objArr = Object.keys(value);
                objArr.forEach(item => {
                    process(key ? `${key}.${item}` : `${item}`, value[item])
                });
                if (objArr.length === 0 && key) {
                    result[key] = {};
                }
            }
        }
        process('', obj)
        return result;
    }


 console.log(flatten({
        a: {
            b: 1,
            c: 2,
            d: { e: 5 }
        },
        b: [1, 3, { a: 2, b: 3 }],
        c: 3
    }));



// 最终效果是执行
flatten({
  a: {
    b: 1,
    c: 2,
    d: {e: 5}
  },
  b: [1, 3, {a: 2, b: 3}],
  c: 3
}) 

// 得到
{
  'a.b': 1,
  'a.c': 2,
  'a.d.e': 5,
  'b[0]': 1,
  'b[1]': 3,
  'b[2].a': 2,
  'b[2].b': 3,
  'c': 3
}          

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值