美文网首页Angular
Angular 组件生命周期

Angular 组件生命周期

作者: 浅忆_0810 | 来源:发表于2021-05-26 23:00 被阅读0次
生命周期

1. 挂载阶段

挂载阶段的生命周期函数只在挂载阶段执行一次,数据更新时不再执行

  1. constructor

    Angular在实例化组件类时执行,可以用来接收 Angular 注入的服务实例对象

    export class ChildComponent {
      constructor (private test: TestService) {
        console.log(this.test)
      }
    }
    
  2. ngOnInit

    在首次接收到输入属性值后执行,在此处可以执行请求操作

    <app-child name="张三"></app-child>
    
    export class ChildComponent implements OnInit {
      @Input("name") name: string = ""
      ngOnInit() {
        console.log(this.name) // "张三"
      }
    }
    
  3. ngAfterContentInit

    当内容投影初始渲染完成后调用

    <app-child>
      <div #box>Hello Angular</div>
    </app-child>
    
    export class ChildComponent implements AfterContentInit {
      @ContentChild("box") box: ElementRef<HTMLDivElement> | undefined
    
      ngAfterContentInit() {
        console.log(this.box) // <div>Hello Angular</div>
      }
    }
    
  4. ngAfterViewInit

    当组件视图渲染完成后调用

    <!-- app-child 组件模板 -->
    <p #p>app-child works</p>
    
    export class ChildComponent implements AfterViewInit {
      @ViewChild("p") p: ElementRef<HTMLParagraphElement> | undefined
      ngAfterViewInit () {
        console.log(this.p) // <p>app-child works</p>
      }
    }
    

2. 更新阶段

  1. ngOnChanges

    • 当输入属性值发生变化时执行,初始设置时也会执行一次,顺序优于 ngOnInit
    • 不论多少输入属性同时变化,钩子函数只会执行一次,变化的值会同时存储在参数中
    • 参数类型为 SimpleChanges,子属性类型为 SimpleChange
    • 对于基本数据类型来说,只要值发生变化就可以被检测到
    • 对于引用数据类型来说,可以检测从一个对象变成另一个对象,但是检测不到同一个对象中属性值的变化,但是不影响组件模板更新数据

    基本数据类型值变化

    <app-child [name]="name" [age]="age"></app-child>
    <button (click)="change()">change</button>
    
    export class AppComponent {
      name: string = "张三";
      age: number = 20
      change() {
        this.name = "李四"
        this.age = 30
      }
    }
    
    export class ChildComponent implements OnChanges {
      @Input("name") name: string = ""
      @Input("age") age: number = 0
    
      ngOnChanges(changes: SimpleChanges) {
        console.log("基本数据类型值变化可以被检测到")
      }
    }
    

    引用数据类型变化

    <app-child [person]="person"></app-child>
    <button (click)="change()">change</button>
    
    export class AppComponent {
      person = { name: "张三", age: 20 }
      change() {
        this.person = { name: "李四", age: 30 }
      }
    }
    
    export class ChildComponent implements OnChanges {
      @Input("person") person = { name: "", age: 0 }
    
      ngOnChanges(changes: SimpleChanges) {
        console.log("对于引用数据类型, 只能检测到引用地址发生变化, 对象属性变化不能被检测到")
      }
    }
    
  2. ngDoCheck:主要用于调试,只要输入属性发生变化,不论是基本数据类型还是引用数据类型还是引用数据类型中的属性变化,都会执行

  3. ngAfterContentChecked:内容投影更新完成后执行

  4. ngAfterViewChecked:组件视图更新完成后执行


3. 卸载阶段

  1. ngOnDestroy

    当组件被销毁之前调用,用于清理操作

    export class HomeComponent implements OnDestroy {
      ngOnDestroy() {
        console.log("组件被卸载")
      }
    }
    

相关文章

  • angular中的生命周期

    生命周期 1、Angular每个组件都存在一个生命周期,从创建,变更到销毁。Angular提供组件生命周期钩子,把...

  • Angular2生命周期钩子函数

    Angular每个组件都存在一个生命周期,从创建,变更到销毁。Angular提供组件生命周期钩子,把这些关键时刻暴...

  • Angular2生命周期钩子函数

    Angular每个组件都存在一个生命周期,从创建,变更到销毁。Angular提供组件生命周期钩子,把这些关键时刻暴...

  • Angular 2+ 的组件生命周期

    参考资料: angular 2.0 从0到1 -> #Angular 2的组件生命周期

  • angular 学习记录(七)

    一、生命周期钩子 当 Angular 实例化组件类并渲染组件视图及其子视图时,组件实例的生命周期就开始了。生命周期...

  • angular 钩子

    angular 钩子ngOnInit是 Angular 组件生命周期中的一个钩子,Angular 中的所有钩子和调...

  • 12.《Angular生命周期》

    一、生命周期钩子 每个组件都有一个被 Angular 管理的生命周期。Angular 创建它,渲染它,创建并渲染它...

  • Angular生命周期

    Angular生命周期 初始化组件生命周期执行顺序 DOM事件setTimeout,setInterval,aja...

  • angular生命周期

    组件生命周期 与其他框架的组件,Angular的组件也是有生命周期这个概念。在不同的阶段不同的场景下,可以调用不同...

  • Angular生命周期解析

    每个组件都有一个被Angular管理的生命周期,Angular提供了生命周期钩子,把这些关键生命时刻暴露出来,赋予...

网友评论

    本文标题:Angular 组件生命周期

    本文链接:https://www.haomeiwen.com/subject/doilsltx.html