0

0

如何将嵌套对象数组转换为结构化键值对数组

花韻仙語

花韻仙語

发布时间:2026-01-02 22:10:02

|

271人浏览过

|

来源于php中文网

原创

如何将嵌套对象数组转换为结构化键值对数组

本文介绍如何将嵌套对象数组转换为结构化键值对数组。本文介绍如何将每个对象元素的键(日期)和值(计数)拆解为标准化的 `{ date: 'yyyy-mm-dd', count: 'x' }` 对象,并支持保留二维结构或展平为一维数组。

在实际开发中,我们常遇到类似 [{ '2023-06-02': 2, '2023-06-21': 6 }, { '2023-06-29': 2, '2023-06-23': 1 }] 这样的数据结构——即一个数组,其每个元素是一个以日期为键、数值为值的对象。但前端渲染(如时间序列图表、日历表格)通常需要更规范的结构:每个数据项为独立对象,明确包含 date 和 count 字段。

解决思路非常清晰:对原数组逐项处理,利用 Object.entries() 将每个对象转为 [key, value] 键值对数组,再通过 .map() 映射为标准对象格式。关键代码如下:

const arrayWithDates = [
  { '2023-06-02': 2, '2023-06-21': 6 },
  { '2023-06-29': 2, '2023-06-23': 1 }
];

const arrayTransformed = arrayWithDates.map(record =>
  Object.entries(record).map(([date, count]) => ({
    count: String(count), // 确保 count 为字符串类型(按需求可改为 number)
    date
  }))
);

console.log(arrayTransformed);
// 输出:二维数组,保持原始分组结构

输出结果

[
  [{ "count": "2", "date": "2023-06-02" }, { "count": "6", "date": "2023-06-21" }],
  [{ "count": "2", "date": "2023-06-29" }, { "count": "1", "date": "2023-06-23" }]
]

若需扁平化为单一列表(例如统一供列表组件或图表库消费),只需链式调用 .flat():

01Agent
01Agent

多平台AI图文创作智能体

下载
const flatTransformed = arrayWithDates
  .map(record => Object.entries(record).map(([date, count]) => ({ 
    count: String(count), 
    date 
  })))
  .flat();

console.log(flatTransformed);
// 输出:一维数组,共 4 个对象

⚠️ 注意事项

  • 原始数据中键名含连字符(如 '2023-06-02'),必须用引号包裹定义,否则会因语法错误(减法运算)导致解析失败;
  • Object.entries() 返回的键始终为字符串,因此 date 字段天然兼容 ISO 格式;
  • 若需 count 保持数字类型(如用于计算),可将 String(count) 替换为 count;若后续需 JSON 序列化且要求严格字符串类型,则当前写法更稳妥;
  • 该方案具备良好扩展性:如需添加 id、timestamp 等字段,可在内层 .map() 中直接扩展对象属性。

此方法简洁、函数式、无副作用,适用于现代浏览器及 Node.js 环境(ES2017+),是处理“键即维度、值即指标”类数据的标准实践。

相关专题

更多
json数据格式
json数据格式

JSON是一种轻量级的数据交换格式。本专题为大家带来json数据格式相关文章,帮助大家解决问题。

403

2023.08.07

json是什么
json是什么

JSON是一种轻量级的数据交换格式,具有简洁、易读、跨平台和语言的特点,JSON数据是通过键值对的方式进行组织,其中键是字符串,值可以是字符串、数值、布尔值、数组、对象或者null,在Web开发、数据交换和配置文件等方面得到广泛应用。本专题为大家提供json相关的文章、下载、课程内容,供大家免费下载体验。

529

2023.08.23

jquery怎么操作json
jquery怎么操作json

操作的方法有:1、“$.parseJSON(jsonString)”2、“$.getJSON(url, data, success)”;3、“$.each(obj, callback)”;4、“$.ajax()”。更多jquery怎么操作json的详细内容,可以访问本专题下面的文章。

307

2023.10.13

go语言处理json数据方法
go语言处理json数据方法

本专题整合了go语言中处理json数据方法,阅读专题下面的文章了解更多详细内容。

74

2025.09.10

string转int
string转int

在编程中,我们经常会遇到需要将字符串(str)转换为整数(int)的情况。这可能是因为我们需要对字符串进行数值计算,或者需要将用户输入的字符串转换为整数进行处理。php中文网给大家带来了相关的教程以及文章,欢迎大家前来学习阅读。

312

2023.08.02

counta和count的区别
counta和count的区别

Count函数用于计算指定范围内数字的个数,而CountA函数用于计算指定范围内非空单元格的个数。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

193

2023.11.20

js 字符串转数组
js 字符串转数组

js字符串转数组的方法:1、使用“split()”方法;2、使用“Array.from()”方法;3、使用for循环遍历;4、使用“Array.split()”方法。本专题为大家提供js字符串转数组的相关的文章、下载、课程内容,供大家免费下载体验。

251

2023.08.03

js截取字符串的方法
js截取字符串的方法

js截取字符串的方法有substring()方法、substr()方法、slice()方法、split()方法和slice()方法。本专题为大家提供字符串相关的文章、下载、课程内容,供大家免费下载体验。

206

2023.09.04

php源码安装教程大全
php源码安装教程大全

本专题整合了php源码安装教程,阅读专题下面的文章了解更多详细内容。

149

2025.12.31

热门下载

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

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
WEB前端教程【HTML5+CSS3+JS】
WEB前端教程【HTML5+CSS3+JS】

共101课时 | 8.1万人学习

JS进阶与BootStrap学习
JS进阶与BootStrap学习

共39课时 | 3.1万人学习

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

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