详解Angular组件生命周期(一)

  

Angular组件生命周期是Angular框架用来管理组件生命周期的一种机制,用于确保组件能够在运行时按照正确的顺序进行初始化、渲染、销毁等操作。在这篇文章中,我们将详细讲解Angular组件的生命周期。本章主要介绍组件的构造以及ngOnChanges的生命周期函数。

组件的构造

每当Angular框架需要实例化一个组件时,都会根据组件定义创建一个新的类实例。然后,Angular框架会自动调用组件类的构造函数。组件类的构造函数即是组件的构造函数,在其中可以进行一些必要的初始化操作。

下面是一个示例代码,展示了在组件的构造函数中进行一些必要的初始化操作:

import { Component } from '@angular/core';

@Component({
  selector: 'app-root',
  templateUrl: './app.component.html',
  styleUrls: ['./app.component.css']
})
export class AppComponent {
  constructor() {
    console.log('AppComponent constructor');
  }
}

在上面的代码中,我们在AppComponent的构造函数中打印一条log,并将其输出到控制台。当我们运行这个代码时,我们会发现在控制台上打印出了一条信息:

AppComponent constructor

这说明我们的构造函数已经被成功调用了。

ngOnChanges

ngOnChanges函数是组件生命周期中重要的一个函数,它是Angular框架用来监测组件属性变化的钩子函数。当组件的输入属性发生变化时,ngOnChanges函数会被自动调用。

下面是一个示例代码,展示了如何使用ngOnChanges函数监测组件属性变化:

import { Component, Input, OnChanges, SimpleChanges } from '@angular/core';

@Component({
  selector: 'app-child',
  template: '<div>{{message}}</div>',
})
export class ChildComponent implements OnChanges {
  @Input() message: string;

  constructor() {}

  ngOnChanges(changes: SimpleChanges) {
    console.log('ngOnChanges', changes);
  }
}

@Component({
  selector: 'app-root',
  template: `
    <div>
      <h3>Parent Component</h3>
      <p><input [(ngModel)]="parentMessage"></p>
      <p>{{parentMessage}}</p>
      <h3>Child Component</h3>
      <app-child [message]="parentMessage"></app-child>
    </div>
  `,
})
export class AppComponent {
  parentMessage = 'Hello World';
}

在上面的代码中,我们定义了一个父组件AppComponent和一个子组件ChildComponent。父组件AppComponent定义了一个message属性,并且将该属性绑定到了子组件ChildComponent的message输入属性上。子组件ChildComponent中,我们定义了一个ngOnChanges函数用来监测子组件的输入属性变化。当父组件AppComponent中message属性发生变化时,ngOnChanges函数会被自动调用,并将变化信息输出到控制台上。

当我们运行这个代码时,我们会发现在控制台上打印出了一条信息:

ngOnChanges {message: SimpleChange}

这说明在父组件AppComponent中,我们成功地修改了message属性的值,并且该变化被自动传递到了子组件ChildComponent中,触发了ngOnChanges函数的调用。

相关文章