首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

如何在angular 6中使用ngFor循环嵌套的json对象?

在Angular 6中使用ngFor循环嵌套的JSON对象,可以通过嵌套的ngFor指令来实现。下面是一个示例:

首先,假设我们有一个嵌套的JSON对象如下:

代码语言:txt
复制
{
  "countries": [
    {
      "name": "China",
      "cities": [
        { "name": "Beijing" },
        { "name": "Shanghai" },
        { "name": "Guangzhou" }
      ]
    },
    {
      "name": "USA",
      "cities": [
        { "name": "New York" },
        { "name": "Los Angeles" },
        { "name": "Chicago" }
      ]
    }
  ]
}

在组件中,我们可以将这个JSON对象赋值给一个变量,比如countries,然后在模板中使用ngFor来循环嵌套的JSON对象,如下所示:

代码语言:txt
复制
<div *ngFor="let country of countries">
  <h1>{{ country.name }}</h1>
  <ul>
    <li *ngFor="let city of country.cities">{{ city.name }}</li>
  </ul>
</div>

在这个例子中,外层的ngFor指令用于循环countries数组,内层的ngFor指令用于循环country对象中的cities数组。通过这样的嵌套使用,我们可以逐层访问和显示JSON对象中的数据。

关于Angular 6的更多详细用法和相关指令,你可以参考腾讯云提供的Angular产品:腾讯云-Serverless Framework

页面内容是否对你有帮助?
有帮助
没帮助

相关·内容

Angular核心概念:数据绑定

Angular核心概念:数据绑定 博客首页:蔚说的博客 欢迎关注点赞收藏⭐️留言 作者水平很有限,如果发现错误,求告知,多谢! 有问题可私信交流!!!...创建对象:N。JSON序列化:N。 NG表达式禁止出现new关键字。NG表达式中JSON是undefined。...{{uname}}">直接在属性上使用 形式2:直接使用[]推荐 注意:属性绑定通常赋值为变量,如果赋值为常量(如字符串常量必须用引号括起来,如循环绑定:ngFor ngFor=“let 临时变量 of 数据”> ngFor=“let 临时变量 of 数据;let i= index”> ngFor=“let...Angular中的指令分三类: 1.组件指令:NG中Component继承自Directive 2.结构型指令:会影响DOM树结构,必须使用开头,如ngFor,*ngIf 3.属性型指令:不会影响DOM

3.6K10
  • AngularDart4.0 指南- 模板语法二 顶

    使用HTML表单元素(如和)的双向绑定会很方便。 但是,没有原生HTML元素遵循x值和xChange事件模式。...警惕隐藏大型组件树; NgIf可能是更安全的选择。 警惕null ngIf指令通常用于防止null。 显示/隐藏是无用的。 如果嵌套表达式试图访问null属性,Angular会抛出一个错误。...分配给* ngFor的文本是指导迭代器进程的指令。 *ngFor微语法 分配给* ngFor的字符串不是模板表达式。 这是一种微语法 - Angular解释的一种小语言。...例如,重新查询服务器可能会重置所有新的英雄对象的列表。 大多数,如果不是全部,以前显示的英雄。 你知道这一点,因为每个英雄的ID没有改变。 但是Angular只能看到新的对象引用列表。...Output属性公开事件生成器,如Stream对象。 术语input和Output反映了目标指令的视角。 ?

    30K20

    ionic3升级适配angular5

    于是我们升级的步骤如下: 一、更新包依赖 删除package-lock.json和node_modules,然后修改package.json如下: "dependencies" : { ......的更新说明: ---- 更改内容: I18n更改; 内置管道如Date、Currency、Percent的更改; 弃用内容: compiler: ngGetContentSelectors()在v4版本被移除...也已经失效; compiler: 编译选项useDebug从v4版本已经弃用且无效,现在移除; common: NgFor在v4版本被弃用,现用NgForOf代替,但不影响在模版中使用*ngFor; common.../common/http中,更新Http模块后,需要使用HttpClientModule替换原有HttpModule,并在使用http服务时,可以去掉map(res=>res.json())的调用,因为新模块中已经不再需要了...若有请求选项,直接用一个any对象(因为原来的RequestOptions已经不用了),如: let options: any = {headers: new Headers()}; 最后删除掉:

    2.5K40

    Angular 从入坑到挖坑 - 表单控件概览

    一、Overview angular 入坑记录的笔记第三篇,介绍 angular 中表单控件的相关概念,了解如何在 angular 中创建一个表单,以及如何针对表单控件进行数据校验。...name 属性则是 angular 用来注册控件的 key,所以在表单中使用 ngModel 进行双向数据绑定时,必须要添加 name 属性 4.2.2、跟踪表单控件的状态 在表单中使用 ngModel...当构建复杂表单时,可以在 FormGroup 中通过嵌套 FormGroup 使表单的结构更合理 import { Component, OnInit } from '@angular/core';...某些情况下,我们只是想要更新控件组中的某个控件的数据值,这时需要使用 patchValue 的方式进行更新 import { Component, OnInit } from '@angular/core...在模板驱动表单中,因为不是直接使用的 FormControl 实例,因此这里应该在模板上添加一个自定义的指令来完成对于控件数据的校验 使用 angular cli 创建一个用来进行表单验证的指令 ng

    18.9K20

    Angular 2.x折腾记 :(2)初步认识angular2,不一样的开发模式

    (polyfill),文件内有详细的注释 typings.d.ts : 全局变量声明的文件 testconfig.*.json: 不同模式下调用的tsconfig配置文件 app目录下(分的很彻底,写起来跟常规基本一样...new运算符 使用;或.的链式表达式 自增或自减操作符 (++和--) 不支持位运算|和& 支持: 逻辑运算(|| , &&) 三目运算符( true ?...b : 会判断item是否有a这个值,防止undefined或者null让视图渲染报错 最常用的内置指令 样式绑定(ngClass) [ngClass]或者[ngStyle]:可以传递一个对象,用来动态判断增加多个样式...[class.a]或者[style.font-size]:单一操作类或者某个行内样式 数据遍历(*ngFor) *ngFor="let i of item; let index = index": 可以用这个来遍历数组对象...总结 这一篇没有涉及到路由这些和表单这些; 准备拆成两个文章来说; 路由的配置及懒加载这些, 模板驱动的表单及响应式表单[嵌套表单响应等],回车键触发搜索等。。

    10810

    AngularDart 4.0 高级-管道 顶

    如果管道接受多个参数,请使用冒号分隔值(如slice:1:5) 修改生日模板以给日期管道一个格式参数。...纯净的管道 仅当Angular检测到对输入值的纯粹更改时才执行纯管道。 在AngularDart中,纯粹的改变仅仅来自对象引用的改变(假设所有东西都是Dart中的对象)。...对象引用检查的速度比深入检查差异要快得多 - 所以Angular可以快速确定它是否可以跳过管道执行和视图更新。 出于这个原因,如果您可以接受变更检测策略,则最好使用纯净的管道。...使用JsonPipe进行调试:JsonPipe提供了一种简单的方法来诊断离奇失败的数据绑定,或者检查未来绑定的对象。 纯净的管道和纯粹的功能 纯管道使用纯功能。...--> ngFor="let hero of heroes | orderBy:'name,planet'"> 您通过文本字符串来识别排序字段,期望管道通过索引引用属性值(如hero

    6.4K20

    Angular 2 + 折腾记 :(2)初步认识angular2,不一样的开发模式

    (polyfill)..有详细的注释 typings.d.ts : 全局变量声明的文件 testconfig.*.json: 不同模式下调用的tsconfig配置文件 app目录下(分的很彻底,...绑定赋值的条件表达式的特殊之处: 不支持: 赋值 (=, +=, -=, ...) new运算符 使用;或,的链式表达式 自增或自减操作符 (++和--) 不支持位运算|和& 支持: 逻辑运算(...,用来动态判断增加多个样式 [class.a]或者[style.font-size]:单一操作类或者某个行内样式 数据遍历(*ngFor) *ngFor="let i of item; let index...= index": 可以用这个来遍历数组对象,let index = index意思是创建一个局部遍历把当前遍历的索引保存到你的自定义变量index 动态渲染(*ngIf) *ngIf="item"...---- 总结 这一篇没有涉及到路由这些和表单这些; 准备拆成两个文章来说; 路由的配置及懒加载这些, 模板驱动的表单及响应式表单[嵌套表单响应等],回车键触发搜索等。。

    6.2K20

    Angular 从入坑到挖坑 - 组件食用指南

    一、Overview angular 入坑记录的笔记第二篇,介绍组件中的相关概念,以及如何在 angular 中通过使用组件来完成系统功能的实现 对应官方文档地址: 显示数据 模板语法 用户输入 组件之间的交互...:数据对象 分类 语法 单向从数据源到视图 1、插值表达式:{{expression}}2、使用 [] 进行绑定:3、使用 bind 进行绑定:<a...,再次显示时不用重新进行初始化过程 NgFor:通过定义单条数据的显示格式,angular 以此为模板,循环渲染出所有的数据 ngFor="let item of products; let...,此时当渲染的数据发生改变时,只会重新渲染变更了指定的属性值的数据 不使用 trackBy 跟踪属性 ngFor="let item of products; let...,添加了三个特殊的运算符 管道运算符 管道是一种特殊的函数,可以把运算符(|)左边的数据转换成期望呈现给视图的数据格式,例如,将时间进行格式化、将数据转换成 json 字符串的形式等等 可以针对一个数据使用多个管道进行串联

    15.8K30

    AngularDart 4.0 高级-结构指令 顶

    NgFor指令具有比本指南中显示的NgIf更多的功能,包括必需的和可选的。 至少NgFor需要一个循环变量(let hero)和一个列表(heroes)。...这些是两个NgFor输入属性的名称。 这就是指令如何得知列表是heroes,并且track-by功能是trackById。 当NgFor指令遍历列表时,它会设置并重置其自己的上下文对象的属性。...ngFor="let hero of heroes">{{hero.name}} 如果没有宿主元素,通常可以将内容包装在本机HTML容器元素(如)中,然后将该指令附加到该容器...指令属性名称应使用lowerCamelCase拼写,并以前缀开头。 不要使用ng。 该前缀属于Angular。 选择适合您或您公司的简短内容。 在这个例子中,前缀是my。...在没有合适的宿主元素时使用作为分组元素。 Angular将星号(*)语法解析为。 NgIf,NgFor和NgSwitch内置指令如何工作。

    16.1K20
    领券