Javascript如何实现对象扁平化

实例详情
// 实现一个 flatten 函数,实现如下的转换功能
const obj = {
  a: 1,
  b: [1, 2, { c: true }],
  c: { e: 2, f: 3 },
  g: null,
};

// 转化为扁平化之后的对象
let objRes = {
  a: 1,
  "b.0": 1,
  "b.1": 2,
  "b.2.c": true,
  "c.e": 2,
  "c.f": 3,
  g: null,
};
扁平化概念的核心意义是:去除冗余、厚重和繁杂的装饰效果。而具体表现在去掉了多余的透视、纹理、渐变以及能做出3D效果的元素,这样可以让“信息”本身重新作为核心被凸显出来。同时在设计元素上,则强调了抽象、极简和符号化。对象实现扁平化,从需要转化的结果可以看出,我们需要对整个对象进行遍历,对象里面嵌套对象或者数组都需要扁平化,将嵌套的内层对象的属性值依次输出。我认为本题的核心就在于传入对象的 key 和 value,对value进行递归遍历,找到所有嵌套的属性值。
function flattenObj(obj) {
	let res = {};
	for (var let key in obj) {
		let res = {};
		for (let key in obj) {
			if (typeof obj[key] === 'object' && obj[key] !== null) {
				flatten(res, obj[key], `${key}`);
			} else {
				res[key] = obj[key];
			}
		}
	}
	function flatten(res, obj, keyname) {
		for (let key in obj) {
			if (typeof obj[key] === 'object' && obj[key] !== null) {
				flatten(res, obj[key], `${keyname}.${key}`);
			} else {
				res[`${keyname}.${key}`] = obj[key]
			}
		}
	}
}
  • 1
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值