如何将嵌套数组的值Map到具有相同构造的对象模板?我已经尝试了一些方法,但仍然不能得到目标,有人可以帮我一个忙吗?这是我从后台得到的原始数据!
const test_array = [
{
"name": "AnyManagedFundsRow",
"columnMeta": {
"a0": "STRING",
"a1": "STRING",
"a2": "STRING",
"a3": "DATE",
"a4": "DATE",
"a5": "DOUBLE",
"a6": "INT"
},
"rows": [
[
"华夏基金管理有限公司",
"华夏大中华企业精选灵活配置混合(QDII)",
"其他型基金",
"2016-01-20",
"",
21.877086009428236,
65135
],
[
"华夏基金管理有限公司",
"华夏大盘精选混合",
"混合型基金",
"2015-09-01",
"2017-05-02",
10.307680340705128,
2944
]
]
}
];
目标数据看起来像下面的结构!
let target_data = [
{
"A0": {
"Description": "华夏基金管理有限公司",,
"type": "STRING"
},
"A1": {
"Description": "华夏大中华企业精选灵活配置混合(QDII)",
"type": "STRING"
},
"A2": {
"Description": "其他型基金",
"type": "STRING"
},
"A3": {
"Description": "2016-01-20",
"type": "DATE"
},
"A4": {
"Description": "",
"type": "DATE"
},
"A5": {
"Description": "21.877086009428236",
"type": "DOUBLE"
},
"A6": {
"Description": "65135",
"type": "INT"
}
},
{
"A0": {
"Description": "华夏基金管理有限公司",,
"type": "STRING"
},
"A1": {
"Description": "华夏大盘精选混合",
"type": "STRING"
},
"A2": {
"Description": "混合型基金",
"type": "STRING"
},
"A3": {
"Description": "2015-09-01",
"type": "DATE"
},
"A4": {
"Description": "2017-05-02",
"type": "DATE"
},
"A5": {
"Description": "10.307680340705128",
"type": "DOUBLE"
},
"A6": {
"Description": "2944",
"type": "INT"
}
}
];
部分OK。如何使用索引来迭代对象?c_obj[index] = value;
const test_array = [
{
"name": "AnyManagedFundsRow",
"columnMeta": {
"a0": "STRING",
"a1": "STRING",
"a2": "STRING",
"a3": "DATE",
"a4": "DATE",
"a5": "DOUBLE",
"a6": "INT"
},
"rows": [
[
"华夏基金管理有限公司",
"华夏大中华企业精选灵活配置混合(QDII)",
"其他型基金",
"2016-01-20",
"",
21.877086009428236,
65135
],
[
"华夏基金管理有限公司",
"华夏大盘精选混合",
"混合型基金",
"2015-09-01",
"2017-05-02",
10.307680340705128,
2944
]
]
}
];
const tabs_obj = {};
const tabs = test_array.map(
// tab
(tab, index) => {
let p_obj = {},
c_obj = {};
p_obj[tab.name] = [];
// object keys length
let key_length = Object.keys(tab.columnMeta).length;
for (let key in tab.columnMeta) {
let obj = {};
if (tab.columnMeta.hasOwnProperty(key)) {
obj.type = tab.columnMeta[key];
obj.Description = "";
c_obj[key.toUpperCase()] = obj;
// "a0".toUpperCase(); === "A0"
}
console.log(`%c tabs${index} & c_obj[key.toUpperCase] = \n`, "color: #f0f", JSON.stringify(c_obj, null, 2));
// c_obj = {"A0": ""}
}
let t_obj = {};
for(let arr of tab.rows){
arr.map(
(value, index) => {
// c_obj[index] = value;
t_obj[index] = value;
for(key in c_obj){
c_obj[key].Description = value;
}
}
);
}
p_obj[tab.name].push(c_obj);
console.log("%c \n\n finish a c_obj! = \n\n", "color: red", JSON.stringify(c_obj, null, 4));
// c_obj = {"A0": "","A1": "","A2": "",A3: "",A4: "", A5: "", A6: ""}
return p_obj;
}
);
// format JSON : JSON.stringify(c_obj, null, 4)`
3条答案
按热度按时间qnakjoqk1#
您可以迭代这些值并将其Map到它们所分配的类型。
50few1ms2#
我的解决方案。
我喜欢使用ES6(es2015+)的方式。
演示
zysjyyx43#
您可以使用
array#reduce
和Object.keys()
。对于每个rows
,通过迭代columnMeta
创建一个新对象。