0

0

如何将嵌套对象中各层级的键值对合并为一个扁平化对象

花韻仙語

花韻仙語

发布时间:2026-01-13 19:39:01

|

983人浏览过

|

来源于php中文网

原创

如何将嵌套对象中各层级的键值对合并为一个扁平化对象

本文介绍在 laravel + ajax 场景下,将多组带随机键名的对象(如购物车商品数据)合并为单一对象的方法,重点提供 javascript 端高效解决方案,并说明 laravel 端可选优化方式。

在 Laravel 应用中,当购物车数据以关联数组形式(如 session()->get('cart.products'))通过 JSON 响应返回给前端时,常出现类似如下结构:外层为 data1、data2 等分组键,内层则以商品 ID 为键、商品对象为值。但前端通常需要统一处理所有商品——即忽略分组层级,将所有商品条目“扁平化”聚合到一个对象中,保持原始键名(如 1234543、4643345)不变,仅合并值

这并非数组拼接([]),而是对象合并({}):目标是得到一个单层对象,其所有属性均为商品 ID → 商品对象的映射关系。

✅ 推荐方案(前端 JavaScript,简洁高效):

白果AI论文
白果AI论文

论文AI生成学术工具,真实文献,免费不限次生成论文大纲 10 秒生成逻辑框架,10 分钟产出初稿,智能适配 80+学科。支持嵌入图表公式与合规文献引用

下载
// 假设 Ajax 成功回调中 receivedData 即服务端返回的响应对象
const receivedData = {
  data1: {
    '1234543': { id: 1, title: 'Product Title1', description: 'Product Descrition1' },
    '3453234': { id: 2, title: 'Product Title2', description: 'Product Descrition2' },
    '4564234': { id: 3, title: 'Product Title3', description: 'Product Descrition3' }
  },
  data2: {
    '4643345': { id: 4, title: 'Product Title4', description: 'Product Descrition4' },
    '8679673': { id: 5, title: 'Product Title5', description: 'Product Descrition5' },
    '2344565': { id: 6, title: 'Product Title6', description: 'Product Descrition6' }
  }
};

// 一行代码完成合并:提取所有子对象 → 展开为参数 → 合并为单个对象
const flattenedProducts = Object.assign({}, ...Object.values(receivedData));
console.log(flattenedProducts);
// 输出:
// {
//   '1234543': { id: 1, ... },
//   '3453234': { id: 2, ... },
//   '4564234': { id: 3, ... },
//   '4643345': { id: 4, ... },
//   '8679673': { id: 5, ... },
//   '2344565': { id: 6, ... }
// }

? 原理说明:

  • Object.values(receivedData) → 返回 [data1对象, data2对象];
  • ... 展开运算符将其转为独立参数;
  • Object.assign({}, ...) 将所有子对象的自有可枚举属性逐个复制到空对象 {} 中;
  • 因键名唯一(商品 ID 全局不重复),无覆盖风险,天然实现“去分组、保键名、合数据”。

⚠️ 注意事项:

  • 此方法要求环境支持 ES2015+(现代浏览器及 Node.js ≥ 6.0);
  • 若需兼容老旧浏览器(如 IE),可改用 reduce + Object.keys() 方案:
    const flattened = Object.values(receivedData).reduce((acc, obj) => {
      Object.keys(obj).forEach(key => acc[key] = obj[key]);
      return acc;
    }, {});
  • Laravel 端也可提前处理(非必需):若业务逻辑允许,可在控制器中使用 array_merge(...array_values($cartProducts)) 合并后再响应,减少前端负担;但注意 PHP 关联数组合并后键名仍保留,与 JS 行为一致。

? 总结:
面对多层级、键名动态的商品数据结构,优先在前端用 Object.assign(...Object.values()) 实现零成本扁平化——语义清晰、性能优异、无需额外依赖。该模式同样适用于其他类似场景,如权限菜单合并、多区域配置聚合等。

相关专题

更多
php文件怎么打开
php文件怎么打开

打开php文件步骤:1、选择文本编辑器;2、在选择的文本编辑器中,创建一个新的文件,并将其保存为.php文件;3、在创建的PHP文件中,编写PHP代码;4、要在本地计算机上运行PHP文件,需要设置一个服务器环境;5、安装服务器环境后,需要将PHP文件放入服务器目录中;6、一旦将PHP文件放入服务器目录中,就可以通过浏览器来运行它。

2485

2023.09.01

php怎么取出数组的前几个元素
php怎么取出数组的前几个元素

取出php数组的前几个元素的方法有使用array_slice()函数、使用array_splice()函数、使用循环遍历、使用array_slice()函数和array_values()函数等。本专题为大家提供php数组相关的文章、下载、课程内容,供大家免费下载体验。

1581

2023.10.11

php反序列化失败怎么办
php反序列化失败怎么办

php反序列化失败的解决办法检查序列化数据。检查类定义、检查错误日志、更新PHP版本和应用安全措施等。本专题为大家提供php反序列化相关的文章、下载、课程内容,供大家免费下载体验。

1479

2023.10.11

php怎么连接mssql数据库
php怎么连接mssql数据库

连接方法:1、通过mssql_系列函数;2、通过sqlsrv_系列函数;3、通过odbc方式连接;4、通过PDO方式;5、通过COM方式连接。想了解php怎么连接mssql数据库的详细内容,可以访问下面的文章。

952

2023.10.23

php连接mssql数据库的方法
php连接mssql数据库的方法

php连接mssql数据库的方法有使用PHP的MSSQL扩展、使用PDO等。想了解更多php连接mssql数据库相关内容,可以阅读本专题下面的文章。

1414

2023.10.23

html怎么上传
html怎么上传

html通过使用HTML表单、JavaScript和PHP上传。更多关于html的问题详细请看本专题下面的文章。php中文网欢迎大家前来学习。

1234

2023.11.03

PHP出现乱码怎么解决
PHP出现乱码怎么解决

PHP出现乱码可以通过修改PHP文件头部的字符编码设置、检查PHP文件的编码格式、检查数据库连接设置和检查HTML页面的字符编码设置来解决。更多关于php乱码的问题详情请看本专题下面的文章。php中文网欢迎大家前来学习。

1445

2023.11.09

php文件怎么在手机上打开
php文件怎么在手机上打开

php文件在手机上打开需要在手机上搭建一个能够运行php的服务器环境,并将php文件上传到服务器上。再在手机上的浏览器中输入服务器的IP地址或域名,加上php文件的路径,即可打开php文件并查看其内容。更多关于php相关问题,详情请看本专题下面的文章。php中文网欢迎大家前来学习。

1305

2023.11.13

php与html混编教程大全
php与html混编教程大全

本专题整合了php和html混编相关教程,阅读专题下面的文章了解更多详细内容。

3

2026.01.13

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
PHP课程
PHP课程

共137课时 | 8.6万人学习

JavaScript ES5基础线上课程教学
JavaScript ES5基础线上课程教学

共6课时 | 6.9万人学习

PHP新手语法线上课程教学
PHP新手语法线上课程教学

共13课时 | 0.9万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号