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改变对象结构
基础教程推荐
猜你喜欢
- 如何添加到目前为止的天数? 2022-01-01
- npm start 错误与 create-react-app 2022-01-01
- 原生拖动事件后如何获取 mouseup 事件? 2022-01-01
- fetch 是否支持原生多文件上传? 2022-01-01
- Bokeh Div文本对齐 2022-01-01
- 即使用户允许,Gmail 也会隐藏外部电子邮件图片 2022-01-01
- Bootstrap 模态出现在背景下 2022-01-01
- 检查 HTML5 拖放文件类型 2022-01-01
- 在 contenteditable 中精确拖放 2022-01-01
- Fabric JS绘制具有活动形状的多边形 2022-01-01
