如何高效地将嵌套对象数组扁平化为属性扩展的数组
发布时间 - 2026-01-09 00:00:00 点击率:次本文介绍一种使用 `map` 与对象遍历结合的方式,将含 `items`(子对象数组)的原始对象数组,转换为每个对象直接包含 `productx` 对应值作为键、`quantity` 作为值的新数组。方法简洁、可读性强,且不修改原始数据。
在实际开发中,我们常遇到需要“展开”嵌套结构的场景:原始数据中每个对象的 items 字段是一个对象数组,每个子对象形如 { productOne: "crust", quantity: 2.2 },而目标是将这些键值对动态提升为外层对象的自有属性(如 crust: 2.2),同时移除 items 字段。
以下是一个健壮、可复用的转换函数:
function flattenItems(arr) {
return arr.map(original => {
// 浅拷贝原对象,避免副作用
const result = { ...original };
// 遍历 items 中每个子项
for (const item of original.items || []) {
let key, value;
// 动态识别非 quantity 字段作为属性名,quantity 值作为属性值
for (const [k, v] of Object.entries(item)) {
if (k === 'quantity') {
value = v;
} else {
key = v; // 注意:此处 v 是字符串值(如 "crust"),即新属性名
}
}
// 安全赋值:仅当 key 和 value 均存在时才扩展
if (key !== undefined && value !== undefined) {
result[key] = value;
}
}
// 移除 items 字段
delete result.items;
return result;
});
}✅ 使用示例:
const firstArray = [
{
amount: 343,
code: "RCU8YI0NKS",
items: [
{ productOne: "crust", quantity: 2.2 },
{ productTwo: "dust", quantity: 34 }
],
user_id: "wewewefwOHG22323kj"
},
{
amount: 343,
code: "RCU8YI0NKS",
items: [
{ productTw
o: "dust", quantity: 32 },
{ productThree: "must", quantity: 34 }
],
user_id: "m2LgLRD9MEVNAX56JTpRYDkOOjd2"
}
];
console.log(flattenItems(firstArray));
// 输出即为目标格式 secondArray⚠️ 注意事项:
- 若某 item 中存在多个非 quantity 字段(如同时有 productOne 和 productTwo),当前逻辑仅取最后一个遍历到的非 quantity 键对应值作为属性名 —— 这符合原始数据结构(每个 item 固定一个产品字段 + 一个 quantity 字段);
- 建议增加空值防护(如 original.items?.length 判断),尤其在数据可能缺失 items 时;
- 属性名冲突(如两个 item 的 product 值相同)会导致后写入覆盖前写入,若需合并逻辑(如累加 quantity),需另行扩展;
- 时间复杂度为 O(n × m)(n 为外层数组长度,m 为平均 items 长度),已是该问题的最优解,无可避免的线性扫描。
该方案兼顾可读性、安全性与扩展性,适用于大多数类似的数据规整需求。
# 键值对
# 数据结构
# Length
# map
# 对象
# 遍历
# 是一个
# 移除
# 原始数据
# 多个
# 适用于
# 已是
# 转换为
# 时才
相关栏目:
【
网站优化151355 】
【
网络推广146373 】
【
网络技术251813 】
【
AI营销90571 】
相关推荐:
高防网站服务器:DDoS防御与BGP线路的AI智能防护方案
怎么用AI帮你为初创公司进行市场定位分析?
Laravel中间件如何使用_Laravel自定义中间件实现权限控制
Laravel怎么防止CSRF攻击_Laravel CSRF保护中间件原理与实践
Python结构化数据采集_字段抽取解析【教程】
如何用5美元大硬盘VPS安全高效搭建个人网站?
Windows10电脑怎么设置虚拟光驱_Win10右键装载ISO镜像文件
惠州网站建设制作推广,惠州市华视达文化传媒有限公司怎么样?
Laravel如何优雅地处理服务层_在Laravel中使用Service层和Repository层
Laravel如何使用Facades(门面)及其工作原理_Laravel门面模式与底层机制
如何在Windows环境下新建FTP站点并设置权限?
JavaScript如何实现倒计时_时间函数如何精确控制
Gemini手机端怎么发图片_Gemini手机端发图方法【步骤】
怎么制作网站设计模板图片,有电商商品详情页面的免费模板素材网站推荐吗?
谷歌浏览器下载文件时中断怎么办 Google Chrome下载管理修复
Laravel Octane如何提升性能_使用Laravel Octane加速你的应用
IOS倒计时设置UIButton标题title的抖动问题
Laravel怎么实现模型属性转换Casting_Laravel自动将JSON字段转为数组【技巧】
,怎么在广州志愿者网站注册?
Laravel表单请求验证类怎么用_Laravel Form Request分离验证逻辑教程
Laravel的Blade指令怎么自定义_创建你自己的Laravel Blade Directives
网站设计制作书签怎么做,怎样将网页添加到书签/主页书签/桌面?
大连企业网站制作公司,大连2025企业社保缴费网上缴费流程?
如何在HTML表单中获取用户输入并用JavaScript动态控制复利计算循环
Laravel如何编写单元测试和功能测试?(PHPUnit示例)
深圳防火门网站制作公司,深圳中天明防火门怎么编码?
如何自定义safari浏览器工具栏?个性化设置safari浏览器界面教程【技巧】
成都品牌网站制作公司,成都营业执照年报网上怎么办理?
Python并发异常传播_错误处理解析【教程】
品牌网站制作公司有哪些,买正品品牌一般去哪个网站买?
JavaScript如何实现路由_前端路由原理是什么
如何用PHP工具快速搭建高效网站?
Laravel如何实现数据导出到PDF_Laravel使用snappy生成网页快照PDF【方案】
Laravel Docker环境搭建教程_Laravel Sail使用指南
微信小程序 canvas开发实例及注意事项
Python制作简易注册登录系统
Android仿QQ列表左滑删除操作
米侠浏览器网页背景异常怎么办 米侠显示修复
php嵌入式断网后怎么恢复_php检测网络重连并恢复硬件控制【操作】
如何在IIS中新建站点并配置端口与IP地址?
宙斯浏览器视频悬浮窗怎么开启 边看视频边操作其他应用教程
标准网站视频模板制作软件,现在有哪个网站的视频编辑素材最齐全的,背景音乐、音效等?
韩国网站服务器搭建指南:VPS选购、域名解析与DNS配置推荐
jQuery 常见小例汇总
Laravel如何使用Eloquent进行子查询
中山网站制作网页,中山新生登记系统登记流程?
JavaScript常见的五种数组去重的方式
Laravel API路由如何设计_Laravel构建RESTful API的路由最佳实践
百度输入法ai组件怎么删除 百度输入法ai组件移除工具
手机网站制作与建设方案,手机网站如何建设?


o: "dust", quantity: 32 },
{ productThree: "must", quantity: 34 }
],
user_id: "m2LgLRD9MEVNAX56JTpRYDkOOjd2"
}
];
console.log(flattenItems(firstArray));
// 输出即为目标格式 secondArray