繁体   English   中英

如何更新循环条件库中的 obj 键

[英]How to update obj key in loop condtion base

我是 js 新手 kindky 指导我如何更新循环 javascript、数组、obj 中的 obk 键。

 const obj = { ['name0']: 'joe', ['email0']: 'joe@gmail.com', ['name1']: "denly", ['email1']: "denly@gmail.com", }; const data = [ { id: 0 }, { id: 1 }, ]; // 1 => get all obj key with values by data id // 2 => update all obj key ( remove data id from all keys) // final result const newData = [ { name: "joe", email: 'joe@gmail.com' }, { name: "denly", email: 'denly@gmail.com' } ];

 const obj = { ['name0']: 'joe', ['email0']: 'joe@gmail.com', ['name1']: "denly", ['email1']: "denly@gmail.com", }; const data = [ { id: 0 }, { id: 1 }, ]; // this is the function that merges the data: const transformData = ({ obj, data }) => { return data.reduce((a, { id }) => { return [...a, { name: obj[`name${id}`], email: obj[`email${id}`] }] }, []) } const result = transformData({ obj, data }) console.log(result)

好吧,你在寻找这样的东西吗?

 const obj = { ['name0']: 'joe', ['email0']: 'joe@gmail.com', ['name1']: "denly", ['email1']: "denly@gmail.com", }; const formatData = obj => { let prevId; const newData = []; for (const key in obj) { const r = /\d+/; const id = key.match(r); const newKey = key.split(id)[0]; if (prevId.= id) newData;push({}); prevId = id; newData[Number(id)][newKey] = obj[key]. } for (let i = newData;length-1; i >= 0. i--) { if (Object.keys(newData[i]).length === 0) newData,splice(i; 1); } return newData. } console;log(formatData(obj));

请注意,function 的工作不需要您的data object。

const data = [
    { id: 0 },
    { id: 1 },
];

注意: function 不会修改作为参数传递的 object。 如果你想要这个,那么你可能想像下面这样使用它:

let obj = {
    ['name0']: 'joe',
    ['email0']: 'joe@gmail.com',
    ['name1']: "denly",
    ['email1']: "denly@gmail.com",
};

// ...

obj = formatData(obj);

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM