0

0

如何在 Angular 模板中遍历 JSON 对象并显示键值对

花韻仙語

花韻仙語

发布时间:2026-01-29 20:23:09

|

492人浏览过

|

来源于php中文网

原创

如何在 Angular 模板中遍历 JSON 对象并显示键值对

本文详解如何使用 angular 内置的 `keyvaluepipe` 遍历任意 json 对象(非数组),在 html 模板中以 `

  • ` 列表形式清晰展示 `key: value` 结构,特别适用于对比展示“前/后”数据变更场景。

    在 Angular 中,*ngFor 默认仅支持可迭代对象(如数组),但 JSON 对象本身不可直接遍历。幸运的是,Angular 提供了内置管道 KeyValuePipe(自 v6.1 起可用),它能将对象自动转换为 {key: string, value: any}[] 形式的数组,从而完美适配 *ngFor。

    ✅ 正确的数据结构准备(TypeScript 层)

    关键前提是:确保组件 TS 文件中定义的属性名与模板中引用的名称完全一致,且结构扁平化。避免多层嵌套导致路径错误。

    根据你的 Handlebars 模板逻辑,应将数据简化为:

    // 在组件类中(例如 email-preview.component.ts)
    export class EmailPreviewComponent implements OnInit {
      Previous: Record<string, any> = {};
      Current: Record<string, any> = {};
    
      ngOnInit() {
        // 假设你已通过服务或输入获取到 formData
        const formData = {
          Message_Body: {
            formChanges: {
              Previous: { Events: 'TEST', AdditionalInfo: '' },
              Current: { Events: 'TEST111', AdditionalInfo: 'test' }
            }
          }
        };
    
        this.Previous = formData.Message_Body.formChanges.Previous;
        this.Current = formData.Message_Body.formChanges.Current;
      }
    }
    ⚠️ 注意:原代码中 templateInput = { Message_Body: { Previous, Current } } 会导致模板需写成 Message_Body.Message_Body.Previous —— 这是常见错误根源。务必解构赋值为顶层属性(如 Previous / Current),提升可读性与健壮性。

    ✅ HTML 模板:用 | keyvalue 管道遍历对象

    在 .html 文件中,直接使用 *ngFor + keyvalue 管道即可:

    <div>
      <h3>Title: This following has been changed!</h3>
    
      <h3>Previous Values</h3>
      <ul *ngIf="Previous && Object.keys(Previous).length > 0; else noPrev">
        <li *ngFor="let item of Previous | keyvalue">
          {{ item.key }}: {{ item.value === '' || item.value == null ? '(empty)' : item.value }}
        </li>
      </ul>
      <ng-template #noPrev><p><em>No previous values.</em></p></ng-template>
    
      <h3>Current Values</h3>
      <ul *ngIf="Current && Object.keys(Current).length > 0; else noCurr">
        <li *ngFor="let item of Current | keyvalue">
          {{ item.key }}: {{ item.value === '' || item.value == null ? '(empty)' : item.value }}
        </li>
      </ul>
      <ng-template #noCurr><p><em>No current values.</em></p></ng-template>
    </div>

    ✅ 效果输出:

    Title: This following has been changed!
    
    Previous Values
    • Events: TEST
    • AdditionalInfo: (empty)
    
    Current Values
    • Events: TEST111
    • AdditionalInfo: test

    ? 补充说明与最佳实践

    • keyvalue 管道默认按插入顺序排序(Angular ≥ 12),如需按字母序排列键,可传入比较函数:

      度加创作工具
      度加创作工具

      百度出品的、人人可用的AIGC创作平台

      下载
      <li *ngFor="let item of Previous | keyvalue: compareKeys">
      compareKeys = (a: KeyValue<string, any>, b: KeyValue<string, any>) => 
        a.key.localeCompare(b.key);
    • 空值/undefined 安全处理:模板中使用 item.value === '' 显式判断空字符串(HTML 渲染时 {{ '' }} 会留白,建议统一提示为 (empty) 或 -)。

    • 性能提示:keyvalue 管道在每次变更检测时会创建新数组。若对象极大(>100 键),建议在组件中预处理为数组并 OnPush 策略优化。

    • 替代方案(不推荐):手动在 TS 中 Object.entries(obj) 转数组 → 更冗余,失去模板声明式优势;keyvalue 是 Angular 官方推荐的标准解法。

    掌握 | keyvalue,你就能优雅、简洁、可维护地渲染任意结构化 JSON 数据——无论是配置项、表单快照,还是审计日志中的字段变更对比。

  • 热门AI工具

    更多
    DeepSeek
    DeepSeek

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

    豆包大模型
    豆包大模型

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

    WorkBuddy
    WorkBuddy

    腾讯云推出的AI原生桌面智能体工作台

    腾讯元宝
    腾讯元宝

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

    文心一言
    文心一言

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

    讯飞写作
    讯飞写作

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

    即梦AI
    即梦AI

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

    ChatGPT
    ChatGPT

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

    相关专题

    更多
    TypeScript工程化开发与Vite构建优化实践
    TypeScript工程化开发与Vite构建优化实践

    本专题面向前端开发者,深入讲解 TypeScript 类型系统与大型项目结构设计方法,并结合 Vite 构建工具优化前端工程化流程。内容包括模块化设计、类型声明管理、代码分割、热更新原理以及构建性能调优。通过完整项目示例,帮助开发者提升代码可维护性与开发效率。

    50

    2026.02.13

    TypeScript全栈项目架构与接口规范设计
    TypeScript全栈项目架构与接口规范设计

    本专题面向全栈开发者,系统讲解基于 TypeScript 构建前后端统一技术栈的工程化实践。内容涵盖项目分层设计、接口协议规范、类型共享机制、错误码体系设计、接口自动化生成与文档维护方案。通过完整项目示例,帮助开发者构建结构清晰、类型安全、易维护的现代全栈应用架构。

    200

    2026.02.25

    TypeScript类型系统进阶与大型前端项目实践
    TypeScript类型系统进阶与大型前端项目实践

    本专题围绕 TypeScript 在大型前端项目中的应用展开,深入讲解类型系统设计与工程化开发方法。内容包括泛型与高级类型、类型推断机制、声明文件编写、模块化结构设计以及代码规范管理。通过真实项目案例分析,帮助开发者构建类型安全、结构清晰、易维护的前端工程体系,提高团队协作效率与代码质量。

    121

    2026.03.13

    json数据格式
    json数据格式

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

    458

    2023.08.07

    json是什么
    json是什么

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

    549

    2023.08.23

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

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

    337

    2023.10.13

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

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

    84

    2025.09.10

    string转int
    string转int

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

    1091

    2023.08.02

    Python WebSocket实时通信与异步服务开发实践
    Python WebSocket实时通信与异步服务开发实践

    本专题聚焦 Python 在实时通信场景中的开发实践,系统讲解 WebSocket 协议原理、长连接管理、消息推送机制以及异步服务架构设计。内容包括客户端与服务端通信实现、连接稳定性优化、消息队列集成及高并发处理策略。通过完整案例,帮助开发者构建高效稳定的实时通信系统,适用于聊天应用、实时数据推送等场景。

    7

    2026.03.18

    热门下载

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

    精品课程

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

    共46课时 | 3.7万人学习

    AngularJS教程
    AngularJS教程

    共24课时 | 4.3万人学习

    CSS教程
    CSS教程

    共754课时 | 44.6万人学习

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

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