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

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

NgFor:为列表中的每个项目重复一个模板。 NgSwitch:只显示多个可能元素中的一个。 NgIf  您可以通过向该元素应用NgIf指令(称为宿主元素)来添加或移除DOM中的元素。...*ngFor和trackBy NgFor指令可能表现不佳,特别是在大型列表中。 对一个项目,删除项目或添加项目的小改动可以触发DOM操作的级联。...它别无选择,只能拆除旧的DOM元素并插入所有新的DOM元素。 Angular可以通过trackBy避免这种流失。 向组件添加一个返回NgFor应跟踪值的方法。 在这个例子中,这个值就是英雄的ID。...NgSwitchCase和NgSwitchDefault指令是结构指令,因为它们添加或删除DOM中的元素。 NgSwitchCase在其绑定值等于交换机值时将其元素添加到DOM。...模板引用变量警告说明 模板引用变量(#phone)与模板输入变量(let phone)不同,如您在*ngFor中可能看到的那样。 了解“结构指令”指南中的差异。 引用变量的范围是整个模板。

30K20
  • 您找到你想要的搜索结果了吗?
    是的
    没有找到

    AngularDart 4.0 高级-结构指令 顶

    它们通常通过添加,移除或操纵元素来塑造或重塑DOM的结构。 与其他指令一样,您将结构指令应用于宿主元素。 然后该指令会执行它应该对该宿主元素及其后代所做的任何操作。 结构指令很容易识别。... ngIf指令不会隐藏CSS元素。 它从DOM中物理添加和删除它们。 使用浏览器开发人员工具确认事实,以检查DOM。 ? 顶部段落在DOM中。...ngFor字符串之外的所有内容仍在宿主元素()中且移动到时保持不变。 在这个例子中,[ngClass] =“odd”保留在上。...ngFor="let hero of heroes">{{hero.name}} 如果没有宿主元素,通常可以将内容包装在本机HTML容器元素(如)中,然后将该指令附加到该容器...import 'package:angular/angular.dart'; @Directive(selector: '[myUnless]') class UnlessDirective { } 该指令的选择器通常是指令的方括号中的属性名称

    16.1K20

    AngularDart4.0 指南- 显示数据 顶

    @Component注解中的CSS选择器指定了一个名为的元素。...在任一种样式中,模板数据绑定都具有对组件属性的相同访问权限。 用* ngFor显示一个列表属性 要显示英雄列表,首先向组件添加英雄名字列表,并将myHero重新定义为列表中的第一个名字。...元素中的* ngFor是Angular“repeater”指令。...它将元素(及其子元素)标记为“repeater模板”: ngFor="let hero of heroes"> {{ hero }}  不要忘记* ngFor中的主要星号...它正在添加和删除DOM中的段落元素。 这可以提高性能,特别是在大型项目中,当有条件地包含或排除大量的HTML与许多数据绑定。 试试看。 由于列表中有四个项目,所以应该显示消息。

    5.3K10

    Angular *ngFor 列表的动画

    如果你想为 ngFor 列表创建一个动画,当移除一个项目时,该项目会淡出,而其下方的剩余项目会缓慢向上滑动,你可以这样做。...:leave 是一个特殊的状态,当元素离开视图时(例如被移除)应用该状态。在过渡中,使用 sequence([...]) 定义了一系列动画步骤。...用于选定具有类名 "call-notification-item" 的组件元素。query 函数通常用于为匹配特定选择器的元素定义动画。...在第一个查询中,包含以下动画序列:style({ opacity: 1 }):将选定元素的初始不透明度设置为 1。...在第二个查询中,包含以下动画序列:animate("800ms ease-in", style({ height: 0 })):以 "ease-in" 的方式在 800 毫秒内将选定元素的高度动画化为

    15610

    Angular 中结构指令模式 - 它们是什么且怎么使用

    在 Angular 中,有两种类型的指令。属性指令修改 DOM 元素的外观或者行为。结构指令添加或者移除 DOM 元素。 结构指令是 Angular 中最强大的特性之一,然而它们却频繁被误解。...这些指令可以添加、移除或者替换元素。结构指令在其名字之前都有 * 符号。 在 Angular 中,有三种标准的结构化指令。...要使用结构指令,我们需要在 HTML 模版中添加一个带有指令的元素。然后根据我们在指令中设置的条件或者表达式添加、删除或者替换元素。 结构指令的例子 我们添加些简单的 HTML 代码。...当表达式是 false 的时候,*ngIf 指令移除 HTML 元素。当为 true 时候,元素的副本会添加到 DOM 中。...Angular 中我们什么时候需要用结构指令呢? 如果你想在 DOM 中添加或者移除一个元素的时候,你就应该使用结构指令。 当然,我们还可以使用它们来更改元素 CSS 样式,或者添加事件监听器。

    3.8K20

    AngularDart4.0 英雄之旅-教程-04明细 顶

    -- each hero goes here --> 下一步你将添加英雄名字 使用ngFor指令罗列英雄 目标是将组件中的英雄列表绑定到模板,迭代它们,并单独显示它们。...通过添加核心指令* ngFor修改标签。 ngFor="let hero of heroes"> ngFor的前缀(*)是此语法的关键部分。...它表示元素及其子元素构成一个主模板。 ngFor指令遍历组件的英雄列表并为该列表中的每个英雄呈现该模板的一个实例。...刷新浏览器,该应用程序不再失败,名称列表再次显示在浏览器中。 当没有选定的英雄时,ngIf指令从DOM中移除英雄详情HTML。 没有英雄细节元素或绑定担心。...您了解了如何在组件模板中使用核心指令ngIf和ngFor。 您在CSS文件中定义了样式,并使用它们来设置应用程序的样式。 你的应用应该看起来像这个实例(查看源代码)。

    3K30

    AngularDart4.0 指南-体系结构概述 顶

    = null" [hero]="selectedHero"> 虽然这个模板使用了典型的HTML元素,如和,但它也有一些不同之处。...注意是如何在原生HTML元素中合适的存放。 自定义组件与原生HTML在相同的布局中无缝混合。 元数据 ? 元数据告诉Angular如何处理一个类。...建筑外包是你必须添加元数据到你的代码,以便Angular知道该怎么做。 数据绑定 如果没有框架,您将负责将数据值推送到HTML控件中,并将用户响应转化为操作和值更新。...它们倾向于以属性的形式出现在元素标签内,有时候以名称的形式出现,但更常见的是作为赋值或绑定的目标。 结构指令通过添加,删除和替换DOM中的元素来改变布局。...如果请求的服务实例不在容器中,那么在将服务返回给Angular之前,注入器将创建一个并将其添加到容器中。 当所有请求的服务已经解析并返回时,Angular可以用这些服务作为参数调用组件的构造函数。

    7.9K30

    AngularDart4.0 高级-组件样式 顶

    上例中的h1选择器仅适用于HeroAppComponent模板中的标记。 应用中其他地方的任何元素都不受影响。 与传统的CSS工作方式相比,这是模块化方面的重大改进。...:host 使用:host伪类选择器来定位承载组件的元素中的样式(而不是定位组件模板中的元素)。...您不能使用其他选择器从组件内部到达宿主元素,因为它不是组件自己的模板的一部分。宿主元素位于父组件的模板中。...通过在:host之后的括号中包含另一个选择器使用函数形式有条件地应用宿主样式 下一个示例再次定位主机元素,但仅限于它还具有activeCSS类。...:host-context()选择器在组件宿主元素的任意祖先中查找CSS类,直到文档根。当与另一个选择器组合时,:host-contex()选择器很有用。

    2.2K20

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

    一、Overview angular 入坑记录的笔记第二篇,介绍组件中的相关概念,以及如何在 angular 中通过使用组件来完成系统功能的实现 对应官方文档地址: 显示数据 模板语法 用户输入 组件之间的交互...selector:选择器,当我们在页面上添加了这个选择器指定的标签()后,就会在当前使用位置上创建并插入这个组件的一个实例 templateUrl...当需要使用这个组件时,直接在页面上添加选择器对应的标签就可以了 ?...模板引用变量是对模板中 DOM 元素的引用,提供了从模块中直接访问元素的能力。...指令上下文中的 index 属性在每次迭代中,会获取到条数据的索引值 当渲染的数据发生改变时 4,会导致 dom 元素的重新渲染,此时可以采用 trackBy 的方式,通过在组件中添加一个方法,指定循环需要跟踪的属性值

    15.8K30

    Angular 显示英雄列表

    列出这些英雄 打开 HeroesComponent 的模板文件,并做如下修改: 在顶部添加  然后添加表示无序列表的 HTML 元素() 在  中插入一个  元素,以显示单个...它会为列表中的每项数据复写它的宿主元素。 在这个例子中  就是 *ngFor 的宿主元素 heroes 就是来自 HeroesComponent 类的列表。...添加 click 事件绑定 再往  元素上插入一句点击事件的绑定代码: heroes.component.html ngFor="let hero of heroes" (click)...给所选英雄添加样式 所有的  元素看起来都是一样的,因此很难从列表中识别出所选英雄。...在 HeroesComponent 模板中的  元素上添加 [class.selected] 绑定,代码如下: heroes.component.html (toggle the 'selected

    4.4K70

    【Appetite】ionic3实录(七)次页实现及分析解决问题【下】

    我们观察initSwiper方法,第一个参数'.wheel .swiper-container'其实是个选择器,所以它也是依托dom操作的,此外,由于我们使用了数据绑定,this.vm.dessertSlides...这并不是说都不要用*ngIf,因为当页面元素太多时会容易导致界面卡顿,所以没用的多余元素应该移除,此时就用它。一句话说就是根据情况合理选择显示控制方法。...是的,在大多场景中可以直接用ion-slides,只是会有个别坑要解决,比如我们改动下ts和html文件。...ts中把initSwiper方法相关内容移除: import { Component, ViewChild, ElementRef, ChangeDetectorRef } from '@angular...='two'" > ngFor="let item of dessertList" > {{item.title}}

    1.5K20

    Angular2 之 结构型指令几个概念

    属性型指令 属性型指令会修改元素的外观或者行为。 e.g. NgStyle可以修改元素的好几个样式。 结构型指令 结构型指令通过添加和删除 DOM 元素来改变DOM的布局。... 移除元素组件 利 把ngIf设置为false,将会影响到组件的资源消耗。angular会从DOM中移除该元素,停止相关组件的变更检测,把它从DOM事件中移除,并且销毁组件。...总结 基于上面的利弊分析,无论是我们在使用内置的指令还是使用自定的指令的时候,我们应该自己分析提添加、移除元素以及创建和销毁组件的后果。...* 我们把它们都作为私有变量注入到构造函数中。 * viewContainer 往这里面去添加,指向的是Template,这是边界,这样界定。...要么显示的包含在Template标签中,要么隐式的使用*这种语法糖去包装在Template标签中。它简化了ngIf和ngFor —— 无论是写还是读。

    3K20
    领券