组件和服务都是简单的类,这些类使用装饰器来标出它们的类型。...Angular充分利用了装饰器(java里的annotation)来标识类的类型,并在装饰器中提供元数据(metadata)来告知ng如何使用它们。...CSS 选择器,它会告诉 Angular,一旦在模板 HTML 中找到了这个选择器对应的标签,就创建并插入该组件的一个实例。...1.3 服务与依赖注入(DI) 对于与特定视图无关并希望跨组件共享的数据或逻辑,可以创建服务类。 服务类的定义通常紧跟在 “@Injectable” 装饰器之后。...如何使用: 在 Angular 中,要把一个类定义为服务,就要用 @Injectable 装饰器来提供元数据,以便让 Angular 可以把它作为依赖注入到组件中 使用 @Injectable 装饰器来表明一个组件或其它类
每个 Angular 应该至少要有一个模块(根模块),一般可以命名为:AppModule。 Angular 模块是一个带有 @NgModule 装饰器的类,它接收一个用来描述模块属性的元数据对象。...几个重要的属性如下: declarations (声明) - 视图类属于这个模块。 Angular 有三种类型的视图类: 组件 、 指令 和 管道 。...创建 Angular 组件的方法有三步: 从 @angular/core 中引入 Component 修饰器 建立一个普通的类,并用 @Component 修饰它 在 @Component 中,设置 selector...你可以把元数据附加到这个类上来告诉 Angular Component 是一个组件。 在 TypeScript 中,我们用 装饰器 (decorator) 来附加元数据。...@Component 装饰器能接受一个配置对象,并把紧随其后的类标记成了组件类。 Angular 会基于这些信息创建和展示组件及其视图。
可能在这样简单的代码中我们还看不出来什么好处,但是在大型的代码库中,这种设计可以显着帮助我们减少样板代码,创建和连接依赖项的工作由一段程序统一处理,我们无需担心创建特定类所需的类的实例。...Decorator API 装饰器模式是一种经典的设计模式,其目的是在不修改被装饰者(如某个函数、某个类等)源码的前提下,为被装饰者增加 / 移除某些功能。...主要用处分为两大类: 收集用户定义的类/函数的信息(例如,用于生成路由表,用于实现依赖注入,等等) 对用户定义的类/函数进行增强,增加额外功能 我们目前用的比较多的装饰器就是 TypeScript 的实验性装饰器...,以及 ECMAScript 中还处于 legacy 阶段的 Decorator API,下面是它的用法: 装饰类的时候,装饰器方法一般会接收一个目标类作为参数,下面是一个示例,给类增加静态属性、原型方法...}; }; @addField class People { } console.log(People.age); const a = new People(); a.speak(); 类属性装饰器可以用在类的属性
常见的装饰器包括类装饰器、方法装饰器、属性装饰器、参数装饰器,类定义中几乎所有的部分都可以被装饰器包装。...以类装饰器为例,它接收的参数是需要被修饰的类,下面的示例中使用@testable修饰符在已经定义的类的原型对象上增加一个名为_testable的属性: function testable(target)...Angular中提供的装饰器通常都可以接收参数,我们只需要借助高阶函数来实现一个“装饰器工厂”,返回一个装饰器生成函数就可以了: // Angular中的组件定义 @Component({ selector...,这里的逻辑就是根据传入的标识符(也就是前文中定义的types),实例化一个元信息对象,然后根据形参的类型来调用不同的处理函数,当装饰器作为参数装饰器时,第三个参数index是该参数在函数形参中的顺序索引...,是数字类型的,否则将认为该装饰器是作为属性装饰器使用的,tagParameter和tagProperty底层调用的是同一个函数,其核心逻辑是在进行了大量的容错检查后,将新的元信息添加到正确的数组中保存起来
当 Angular 渲染它们时,它会根据指令对 DOM 进行修改。 指令是一个带有"指令元数据"的类。在 TypeScript 中,要通过 @Directive 装饰器把元数据附加到类上。...在Angular中包含以下三种类型的指令: 属性指令:以元素的属性形式来使用的指令。 结构指令:用来改变DOM树的结构 组件:作为指令的一个重要子类,组件本质上可以看作是一个带有模板的指令。...为 sites 列表中的每个项生成一个 标签。...创建组件时,会首先为组件所需的服务找一个注入器( Injector ) 。...注入器是一个维护服务实例的容器,存放着以前创建的实例。 如果容器中还没有所请求的服务实例,注入器就会创建一个服务实例,并且添加到容器中,然后把这个服务返回给 Angular 。
angular提供两种地方存放组件模板 你可以使用 template 属性把它定义为内联的, 或者把模板定义在一个独立的 HTML 文件中, 再通过 @Component 装饰器中的 templateUrl...指令创建一个 EventEmitter 实例,并且把它作为属性暴露出来。 指令调用 EventEmitter.emit(payload) 来触发事件,可以传入任何东西作为消息载荷。...输入属性是一个带有 @Input装饰器的可设置属性。...当它通过属性绑定的形式被绑定时,值会“流入”这个属性。 输出属性是一个带有 @Output 装饰器的可观察对象型的属性。 这个属性几乎总是返回 Angular 的EventEmitter。...在这种模式下,有类型的变量默认是不允许 null 或 undefined 值的,如果有未赋值的变量,或者试图把 null 或 undefined 赋值给不允许为空的变量,类型检查器就会抛出一个错误 Angular
import { Injectable } from '@angular/core'; // 在 Angular 中,要把一个类定义为服务,就要用 `@Injectable` 装饰器来提供元数据 @Injectable...一般不用自己手动注入,Angular 会在启动过程中为你创建全应用级注入器以及所需的其它注入器。...Provider 提供商 是一个对象,告诉 Injector 应该如何获取或创建依赖。...LoggerService, 'IS_DEV_ENV' ] }, LoggerService, {provide: 'IS_DEV_ENV', useValue: false} ] 一般来说可以创建一个类型为对象的提供器供注入...我们知道定义组件要写@Component装饰器,定义管道要写@Pipe装饰器,他们都是Injectable的子类。 同时Component又是Directive的子类,所以所有的组件都是指令。
Angular 模块都是一个带有 @NgModule 装饰器的类。 NgModule 是一个装饰器函数,它接收一个用来描述模块属性的元数据对象。...其中最重要的属性是: declarations - 声明本模块中拥有的视图类。Angular 有三种视图类:组件、指令和管道。...元数据 元数据告诉 Angular 如何处理一个类。 @Component 装饰器能接受一个配置对象, Angular 会基于这些信息创建和展示组件及其视图。...@Component 的配置项包括: selector - CSS 选择器,它告诉 Angular 在父级 HTML 中查找标签,创建并插入该组件。...Angular 使用依赖注入来提供新组件以及组件所需的服务。 2. 模板与数据绑定 绑定的类型可以根据数据流的方向分成三类: 从数据源到视图、从视图到数据源以及双向的从视图到数据源再到视图。
与其他指令不同,它描述的是一个视图,是用户可以直接看到的东西。 自定义属性指令 实例:创建一个bgColor属性指令,支持传入颜色名参数,设置目标标签的背景色 1)创建指令。...setStyle(color: string){ this.el.nativeElement.style.backgroundColor = color; } } 改动的只是用@Input装饰器修饰...为实现该功能,我们需要在事件处理函数上添加@HostListener装饰器,代码改动如下: import { Directive, Input, ElementRef, HostListener }...自定义结构指令 实例:山寨一个*ngIf的的收缩显示指令,仅为了起到抛砖引玉效果。...Component——组件 ionic g component ContentEmpty 关于component,太多文章讲了,这里我不详细说明,主要就两个装饰器:@Input、@Output,分别用于属性和事件绑定
Input 是属性装饰器,用来定义组件内的输入属性。在实际应用场合,我们主要用来实现父组件向子组件传递数据。...如果没有指定,则默认使用 @Input 装饰器,装饰的属性名。...---- Output 是属性装饰器,用来定义组件内的输出属性。...中的 EventEmitter 应用场景是: 子指令创建一个 EventEmitter 实例,并将其作为输出属性导出。...如果没有指定,则默认使用 @Output 装饰器,装饰的属性名。
(可以想象成是一个厨师做菜) Provider:用于配置注入器,注入器通过它来创建被依赖对象的实例。...依赖注入的使用 创建可注入服务: import { Injectable } from '@angular/core'; // @Injectable()装饰器,是告诉Angular这是一个可供注入的服务...,是可以不用使用 Injectable 类装饰器。...// 这种方式注册,会注册到每个组件实例自己的注入器上。...Provider的唯一标识,用于定位依赖值,也就是应用中使用的服务名 // 而useClass属性则代表使用哪个服务类来创建实例 }) 复制代码 在模块中注入服务 在根组件\color{#0abb3c
在组件类中,通过使用 @Component 装饰器 1 用来将类声明为组件类,并为这个组件类配置一些元数据 2,以决定该组件在运行期间该如何处理、实例化和使用 装饰器中存在三个基础的配置参数,用来完成组件与视图之间的关联...selector:选择器,当我们在页面上添加了这个选择器指定的标签()后,就会在当前使用位置上创建并插入这个组件的一个实例 templateUrl...4.1.2、模板绑定语法 在 angular 应用中,组件扮演着控制器或是视图模型的作用,在创建组件时会关联一个 html 文件,这个 html 文件则是一个基础的 angular 模板文件 在这个模板文件中...使用 @Output 装饰器配合 EventEmitter 实现 在子组件中引入 Output 和 EventEmitter,通过 @Output 装饰器定义一个事件触发器,然后就可以通过这个事件触发器的...---- 装饰器是一种特殊类型的声明,它能够被附加到类声明,方法, 访问符,属性或参数上,就像是 C# 中的特性↩ 元数据是用来描述数据的数据项,例如这里的 selector 是为了描述 Component
答案就是:元数据反射 先说反射,反射就是在运行时动态获取一个对象的一切信息:方法/属性等等,特点在于动态类型反推导。不管是在 ts 中还是在其他类型语言中,反射的本质在于元数据。...Module 的装饰器,这个装饰器的主要作用就是往装饰的类上添加一些元数据。...然后用装饰器装饰 C 类。...里面有很多成员属性和方法,可以看到其中的私有属性 modules 是一个 ModulesContainer 实例对象,而 ModulesContainer 类是 Map 类的一个子类。...下面 addModule 方法是把 module 添加到 IoC 容器的方法,可以看到,这里针对每个 module 会生成一个 token,然后实例化内建的 Module 类,并放到容器的 modules
方式一 "常规"的取消订阅的方式 最简单的订阅和取消订阅一个可观察对象的方式是在 ngOnInit 方法中订阅可观察对象(Observable), 然后在组件类中创建一个类属性用来保存这个订阅(Subscription...首先, 在组件类中使用new Subscription()实例化创建一个字段, 然后调用该实例的 Subscription.add 方法, 最后在 ngOnDestroy 中取消订阅....然后在组件类中创建一个SubSink类型的字段. SubSink有两种方式, 一种是简单技术(使用sink属性设置器), 另一种是 数组/添加(Array/Add)技术....使用简单技术只需要使用sink设置器属性即可....要使用它我们需要给组件类加上 UntilDestroy 装饰器, 然后在可观察对象管道中加入 untilDestroyed 操作符: @UntilDestroy() @Component({ selector
,我们知道 Angular 内部把不同平台下视图层中的 native 元素封装在 ElementRef 实例的 nativeElement 属性中。...在浏览器环境中,nativeElement 属性指向的就是对应的 DOM 元素。...,不能直接实例化抽象类,只能实例化该抽象类的子类) 作用 利用 TemplateRef 实例,我们可以灵活地创建内嵌视图。...对于列表中声明的每个组件,Angular 将会创建对应的一个 ComponentFactory 对象,并将其存储在 ComponentFactoryResolver 对象中。...实际工作中,还需要利用 ViewChild、ViewChildren、ContentChild 和 ContentChildren 装饰器,或者基于 Angular 依赖注入特性,通过构造注入的方式,获取相关的对象
父组件向子组件传递 子组件通过@Input装饰器定义输入属性,然后父组件在引用子组件的时候通过这些输入属性向子组件传递数据,子组件可通过setter或ngOnChanges()来截听输入属性值的变化。...获取父组件实例 前面介绍的都是子组件通过@Input装饰器定义输入属性,这样父组件可通过输入属性将数据传递给子组件。...当然,我们可以想到一种更主动的方法,那就是获取到父组件实例,然后调用父组件的某个属性或方法来获取需要的数据。考虑到每个组件的实例都会添加到注入器的容器里,因此可通过依赖注入来找到父组件的示例。...一个组件可能是多个组件的子组件,有时候无法直接知道父组件的类型,在Angular中,可通过类—接口(Class-Interface)的方式来查找,即让父组件通过提供一个与类—接口标识同名的别名来协助查找...在上面定义好的子组件和父组件,我们可以看到: 父组件在组件类中通过@ViewChild()获取到子组件的实例,然后就可以在模板或者组件类中通过该实例获取子组件的属性: <!
body{ background:red; } 创建一个组件 创建一个英雄列表组件 ng generate component heroes //可简写:ng g c heroes 要从angular...核心库中导出 Component符号,它是一个装饰器工厂,为组件提供需要的元数据,cli自动生成三个元数据 用于为该被装饰的组件指定 Angular 所需的元数据。...2.CLI自动在app.Module.ts中自动导入HeroesCompent(就是cli刚刚生成的heroes.component.ts中的类) 添加属性 在class中增加属性即可 import...创建src/app/hero.ts,定义一个Hero类型并且导出 export interface Hero{ id:number, name:string } 引入Hero 定义一个属性,\src...class HeroService { constructor() { } } 从rxjs中获取Observable类型和of方法,Observable泛型接口接口一个类型,of方法会可将这个类型包装成
AlertComponent 组件,该组件有一个输入属性 type ,用于让用户自定义提示的类型,此外还包含了一个输出属性 output,用于向外部组件输出信息。...我们的自定义组件最终是一个实际的 DOM 元素,因此如果我们需要在页面中插入该元素,我们就需要考虑在哪里放置该元素。 创建组件容器 在 Angular 中放置组件的地方称为容器。...alertContainer> ` }) export class AppComponent { } 在 AppComponent 组件中,我们可以通过 ViewChild 装饰器来获取视图中的模板元素...调用组件容器对象的 createComponent() 方法创建组件并自动添加动态组件到组件容器中。 基于返回的 ComponentRef 组件实例,配置组件相关属性(可选)。...对于列表中声明的每个组件,Angular 将会创建对应的一个 ComponentFactory 对象,并将其存储在 ComponentFactoryResolver 对象中。
功能化:无状态属性指令,使用顶层函数实现。 创建一个基于类的属性指令 创建一个基于类的属性指令需要编写一个用@Directive()注解的控制器类,它指定标识属性的选择器。...Angular为每个匹配元素创建一个指令控制器类的新实例,将HTML元素注入到构造函数中。...它创建了一个HighlightDirective类的实例,并将元素的引用注入到指令的构造函数中,该构造函数将元素的背景样式设置为黄色。...添加两个事件处理程序,当鼠标进入或离开时进行响应,每个都由HostListener注解装饰。...概要 该页面介绍了如何: 创建一个修改元素行为的基于类的属性指令。 将属性指令应用于模板中的元素。 响应改变基于类的指令行为的事件。 将值绑定到基于类的指令。 编写一个函数化的属性指令。
而 Inject 装饰器一般用来注入非 Type 类型的对象。 使用Inject装饰器 AppModule @NgModule({ ......第七节 - 使用 Input 装饰器 为了让我们能够开发更灵活的组件,Angular 为我们提供了 Input 装饰器,用于定义组件的输入属性。...需要注意的是,当 SimpleFormComponent 组件类的属性名称不是 message 时,我们需要告诉 Angular 如何进行属性值绑定,具体如下: export class SimpleFormComponent...第九节 - 使用 Output 装饰器 Output 装饰器的作用是用来实现子组件将信息,通过事件的形式通知到父级组件。...-- 使用组件实例的属性 --> Using object literal.
领取专属 10元无门槛券
手把手带您无忧上云