0

0

JavaScript中将对象数组转置为属性数组映射的教程

心靈之曲

心靈之曲

发布时间:2025-11-30 14:40:02

|

514人浏览过

|

来源于php中文网

原创

JavaScript中将对象数组转置为属性数组映射的教程

本教程旨在解决将json对象数组转换为键值映射的常见数据处理需求。我们将探讨如何高效地将形如 `[{key1: vala, key2: valb}, ...]` 的数据结构,转置为 ` {key1: [vala, ...], key2: [valb, ...]} ` 的形式。通过一个简洁的javascript函数,本文将详细讲解其实现原理、代码逻辑,并提供完整示例,帮助开发者掌握这一实用的数据转换技巧。

在现代Web开发中,我们经常会遇到需要对数据结构进行转换的场景。其中一个常见的需求是,将一个包含多个JSON对象的数组,转换为一个以原始对象键为属性名、以对应所有值的数组为属性值的对象。这种操作可以被形象地理解为数据表的“转置”,即将行数据转换为列数据。

场景描述与需求分析

假设我们有一个JSON数组,其中每个元素都是一个具有相同或类似结构的JSON对象,例如:

[
 {name: 'Alex', date: '05/17/2023 10:32 PM', id: '00153168', priority: '3-Medium'},
 {name: 'Peter', date: '05/17/2023 11:32 PM', id: '00153169', priority: '3-Medium'}
]

我们的目标是将其转换为以下结构:

{
name : ['Alex','Peter'],
date : ['05/17/2023 10:32 PM','05/17/2023 11:32 PM'],
id: ['00153168','00153169'],
priority: ['3-Medium', '3-Medium']
}

这种转换在数据可视化、数据聚合或特定API接口数据适配时非常有用。直接的迭代和map操作可能会导致逻辑复杂或效率低下,尤其是在处理动态键或非统一结构时。

立即学习Java免费学习笔记(深入)”;

核心实现:转置函数 transpose

为了高效且优雅地实现这一转换,我们可以设计一个名为 transpose 的函数。该函数将遍历输入的对象数组,并动态地构建目标对象。

/**
 * 将对象列表(数组)转换为属性列表(对象)。
 * 该函数能处理非统一结构的对象,缺失值会在对应的数组中保留空位。
 * 实现方式尽可能简洁,不依赖复杂的reducer或重构。
 * @param {Array<Object>} list - 待转置的JSON对象数组。
 * @returns {Object<string, Array<any>>} - 转置后的键值映射对象。
 */
function transpose(list) {
    const result = {}; // 初始化结果对象
    // 遍历输入数组中的每一个对象
    for (let i = 0; i < list.length; i++) {
        // 遍历当前对象的每一个键值对
        // Object.entries() 返回一个给定对象自身可枚举属性的键值对数组。
        for (const [key, value] of Object.entries(list[i])) {
            // 使用 nullish coalescing assignment (??=) 确保 result[key] 是一个数组。
            // 如果 result[key] 为 null 或 undefined,则将其初始化为空数组 []。
            // 否则,保持其现有值(即已存在的数组)。
            // 然后,将当前值 value 赋值给 result[key] 数组的第 i 个位置。
            // 这种方式巧妙地利用了数组索引来填充数据,保持了原始顺序。
            (result[key] ??= [])[i] = value;
        }
    }
    return result;
}

代码逻辑详解

  1. const result = {};

    Article Forge
    Article Forge

    行业文案AI写作软件,可自动为特定主题或行业生成内容

    下载
    • 初始化一个空对象 result,它将用于存储最终的转置结果。这个对象将以原始对象的键作为其属性,属性值将是包含所有对应值的数组。
  2. for (let i = 0; i

    • 这是一个外层循环,用于遍历输入的 list 数组。i 代表当前处理的是 list 中的第 i 个对象。这个 i 值也将在后续用于确定每个属性数组中值的位置。
  3. for (const [key, value] of Object.entries(list[i])) { ... }

    • 这是一个内层循环,对于 list 数组中的每个对象 list[i],它会遍历该对象的所有可枚举属性。
    • Object.entries(list[i]) 方法返回一个数组,其元素是 [key, value] 形式的键值对数组。例如,对于 {name: 'Alex', date: '...'},它会返回 [['name', 'Alex'], ['date', '...']]。
    • 通过解构赋值 const [key, value],我们可以直接获取当前属性的键和值。
  4. (result[key] ??= [])[i] = value;

    • 这是整个函数的核心逻辑,它巧妙地结合了JavaScript的几个特性:
      • result[key] ??= []:这是ES2021引入的空值合并赋值运算符(Nullish Coalescing Assignment)。
        • 它的作用是:如果 result[key] 当前的值是 null 或 undefined,那么就将 [] 赋值给 result[key]。
        • 如果 result[key] 已经有一个非 null 且非 undefined 的值(例如,它已经被初始化为一个数组),那么 result[key] 的值保持不变。
        • 这确保了在第一次遇到某个 key 时,result[key] 会被初始化为一个空数组,而后续遇到相同的 key 时,result[key] 已经是一个数组,可以直接操作。
      • (...)[i] = value;:在 result[key] 确保是一个数组之后,我们将当前 value 赋值给这个数组的第 i 个位置。
        • 由于外层循环的 i 索引与原始对象数组的顺序一致,这意味着所有 name 属性的值将按照它们在原始数组中的顺序,被依次放入 result.name 数组中。同理适用于 date、id、priority 等所有属性。

完整示例

让我们使用提供的示例数据来演示 transpose 函数的用法:

const data = [
 {name: 'Alex', date: '05/17/2023 10:32 PM', id: '00153168', priority: '3-Medium'},
 {name: 'Peter', date: '05/17/2023 11:32 PM', id: '00153169', priority: '3-Medium'}
];

/**
 * 将对象列表(数组)转换为属性列表(对象)。
 * 该函数能处理非统一结构的对象,缺失值会在对应的数组中保留空位。
 * 实现方式尽可能简洁,不依赖复杂的reducer或重构。
 * @param {Array<Object>} list - 待转置的JSON对象数组。
 * @returns {Object<string, Array<any>>} - 转置后的键值映射对象。
 */
function transpose(list) {
    const result = {};
    for (let i = 0; i < list.length; i++) {
        for (const [key, value] of Object.entries(list[i])) {
            (result[key] ??= [])[i] = value;
        }
    }
    return result;
}

const transposedData = transpose(data);
console.log(transposedData);

输出结果:

{
  "name": [
    "Alex",
    "Peter"
  ],
  "date": [
    "05/17/2023 10:32 PM",
    "05/17/2023 11:32 PM"
  ],
  "id": [
    "00153168",
    "00153169"
  ],
  "priority": [
    "3-Medium",
    "3-Medium"
  ]
}

注意事项与总结

  1. 处理非统一结构: transpose 函数的一个优点是它能优雅地处理输入数组中对象结构不完全一致的情况。如果某个对象缺少某个属性,那么在对应的 result[key] 数组中,该位置(由 i 决定)将保持 undefined,这符合预期。例如:
    const mixedData = [
        { name: 'Alice', age: 30 },
        { name: 'Bob', city: 'New York' }
    ];
    const resultMixed = transpose(mixedData);
    // resultMixed 会是:
    // {
    //   name: ['Alice', 'Bob'],
    //   age: [30, undefined], // Bob 没有 age 属性,所以是 undefined
    //   city: [undefined, 'New York'] // Alice 没有 city 属性,所以是 undefined
    // }
  2. 效率: 该方法通过一次遍历输入数组中的所有对象和它们的属性,以 O(N*M) 的时间复杂度(N 为对象数量,M 为平均属性数量)完成了转置,效率较高。
  3. 简洁性: 利用 Object.entries() 和 ??= 运算符,代码非常简洁且易于理解。
  4. 可读性: 函数名 transpose 明确表达了其意图,内部逻辑清晰。

通过本教程,您应该已经掌握了如何在JavaScript中高效地将对象数组转置为属性数组映射的方法。这种数据转换模式在许多数据处理场景中都非常实用,理解并能灵活运用它将极大地提升您的开发效率。

热门AI工具

更多
DeepSeek
DeepSeek

幻方量化公司旗下的开源大模型平台

豆包大模型
豆包大模型

字节跳动自主研发的一系列大型语言模型

通义千问
通义千问

阿里巴巴推出的全能AI助手

腾讯元宝
腾讯元宝

腾讯混元平台推出的AI助手

文心一言
文心一言

文心一言是百度开发的AI聊天机器人,通过对话可以生成各种形式的内容。

讯飞写作
讯飞写作

基于讯飞星火大模型的AI写作工具,可以快速生成新闻稿件、品宣文案、工作总结、心得体会等各种文文稿

即梦AI
即梦AI

一站式AI创作平台,免费AI图片和视频生成。

ChatGPT
ChatGPT

最最强大的AI聊天机器人程序,ChatGPT不单是聊天机器人,还能进行撰写邮件、视频脚本、文案、翻译、代码等任务。

相关专题

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

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

455

2023.08.07

json是什么
json是什么

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

546

2023.08.23

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

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

334

2023.10.13

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

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

82

2025.09.10

c语言中null和NULL的区别
c语言中null和NULL的区别

c语言中null和NULL的区别是:null是C语言中的一个宏定义,通常用来表示一个空指针,可以用于初始化指针变量,或者在条件语句中判断指针是否为空;NULL是C语言中的一个预定义常量,通常用来表示一个空值,用于表示一个空的指针、空的指针数组或者空的结构体指针。

254

2023.09.22

java中null的用法
java中null的用法

在Java中,null表示一个引用类型的变量不指向任何对象。可以将null赋值给任何引用类型的变量,包括类、接口、数组、字符串等。想了解更多null的相关内容,可以阅读本专题下面的文章。

1089

2024.03.01

java基础知识汇总
java基础知识汇总

java基础知识有Java的历史和特点、Java的开发环境、Java的基本数据类型、变量和常量、运算符和表达式、控制语句、数组和字符串等等知识点。想要知道更多关于java基础知识的朋友,请阅读本专题下面的的有关文章,欢迎大家来php中文网学习。

1566

2023.10.24

Go语言中的运算符有哪些
Go语言中的运算符有哪些

Go语言中的运算符有:1、加法运算符;2、减法运算符;3、乘法运算符;4、除法运算符;5、取余运算符;6、比较运算符;7、位运算符;8、按位与运算符;9、按位或运算符;10、按位异或运算符等等。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

241

2024.02.23

C# ASP.NET Core微服务架构与API网关实践
C# ASP.NET Core微服务架构与API网关实践

本专题围绕 C# 在现代后端架构中的微服务实践展开,系统讲解基于 ASP.NET Core 构建可扩展服务体系的核心方法。内容涵盖服务拆分策略、RESTful API 设计、服务间通信、API 网关统一入口管理以及服务治理机制。通过真实项目案例,帮助开发者掌握构建高可用微服务系统的关键技术,提高系统的可扩展性与维护效率。

76

2026.03.11

热门下载

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

精品课程

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

共58课时 | 6万人学习

TypeScript 教程
TypeScript 教程

共19课时 | 3.4万人学习

Bootstrap 5教程
Bootstrap 5教程

共46课时 | 3.6万人学习

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

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