How to change object structure with pure JS(如何用纯JS改变对象结构)
本文介绍了如何用纯JS改变对象结构的处理方法,对大家解决问题具有一定的参考价值,需要的朋友们下面随着小编来一起学习吧!
问题描述
我正在努力改变对象的结构。 我想从此转换对象:
var data = {
"a1.img": 'img1',
"a1.href": 'href1',
"a2.img": 'img2',
"a2.href": 'href2',
"a3.img": 'img3',
"a3.href" : 'href3'
};
到此:
var data = {
"a1":{
"img": "img1",
"href": "href1"
},
"a2":{
"img": "img2",
"href": "href2"
},
"a3":{
"img": "img3",
"href": "href3"
}
}
我的解决方案工作不正常,我不知道如何修复它。我的解决方案:
var data = {
"a1.img": 'img1',
"a1.href": 'href1',
"a2.img": 'img2',
"a2.href": 'href2',
"a3.img": 'img3',
"a3.href": 'href3'
};
var newData = {};
for (var key in data) {
newData[key.split('.')[0]] = {};
for (var i in data) {
newData[key.split('.')[0]][i.split('.')[1]] = data[key]
}
}
console.log(newData)
请帮帮忙。
推荐答案
可以使用Array#reduce
循环原始数组并将属性追加到累加器。
var data = {
"a1.img": 'img1',
"a1.href": 'href1',
"a2.img": 'img2',
"a2.href": 'href2',
"a3.img": 'img3',
"a3.href" : 'href3'
};
var res = Object.entries(data).reduce((a, [k,v]) => {
var [key, prop] = k.split('.');
if (!a[key]) {
a[key] = {};
}
a[key][prop] = v;
return a;
}, {});
console.log(res);
这篇关于如何用纯JS改变对象结构的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持编程学习网!
沃梦达教程
本文标题为:如何用纯JS改变对象结构


猜你喜欢
- 如何使用 JSON 格式的 jQuery AJAX 从 .cfm 页面输出查 2022-01-01
- 失败的 Canvas 360 jquery 插件 2022-01-01
- Quasar 2+Apollo:错误:找不到ID为默认的Apollo客户端。如果您在组件设置之外,请使用ProvideApolloClient() 2022-01-01
- 400或500级别的HTTP响应 2022-01-01
- Css:将嵌套元素定位在父元素边界之外一点 2022-09-07
- Fetch API 如何获取响应体? 2022-01-01
- CSS媒体查询(最大高度)不起作用,但为什么? 2022-01-01
- 使用RSelum从网站(报纸档案)中抓取多个网页 2022-09-06
- Flexslider 箭头未正确显示 2022-01-01
- addEventListener 在 IE 11 中不起作用 2022-01-01