本文介绍如何将一个键值对对象(如语言文化配置)中的特定属性(如 path)精准合并到另一个同键名的数组对象中,实现数据结构的高效融合。
本文介绍如何将一个键值对对象(如语言文化配置)中的特定属性(如 path)精准合并到另一个同键名的数组对象中,实现数据结构的高效融合。
在实际开发中,我们常遇到多源数据需要按标识符(如语言 ISO 代码)进行关联合并的场景。例如:一个以 isoCode 为键的对象 cultures 存储各语言的路径配置,而另一个数组 lang 包含语言元信息(名称、代码、基础 URL),目标是将 cultures 中对应 isoCode 的 path 值注入到 lang 的每个条目中,生成增强后的语言配置列表。
核心思路是利用数组的 map() 方法遍历 lang,对每个对象进行扩展(spread syntax),同时通过 isoCode 作为键从 cultures 对象中安全读取 path 值:
const cultures = { "en-us": { path: "/en/playground/copy/", startItem: { id: "8cd7943c-1ba5-41cb-a9ac-7435fbdb1458", path: "path" } }, "da-dk": { path: "/playground/copy/", startItem: { id: "8cd7943c-1ba5-41cb-a9ac-7435fbdb1458", path: "path" } }};const lang = [ { name: 'English', isoCode: 'en-us', url: '/en/' }, { name: 'Danish', isoCode: 'da-dk', url: '/' }];const result = lang.map(item => ({ ...item, path: cultures[item.isoCode]?.path // 使用可选链确保健壮性}));console.log(result);// 输出:// [// { name: 'English', isoCode: 'en-us', url: '/en/', path: "/en/playground/copy/" },// { name: 'Danish', isoCode: 'da-dk', url: '/', path: "/playground/copy/" }// ]
✅ 关键要点说明:
该方法时间复杂度为 O(n),语义清晰、易于维护,适用于中大型前端项目中的国际化配置组装场景。