生命周期

生命周期和钩子函数

Angular 中每个 component/directive 都有它自己的生命周期。包括创建组件,渲染组件,创建渲染子组件,检测绑定属性变化,回收和从 DOM 中移除。

生命周期有这几种:OnChanges、OnInit、DoCheck、AfterContentInit、AfterContentChecked、AfterViewInit、AfterViewChecked、OnDestroy
钩子函数就是在对应的生命周期前面加上 ng

ngOnChanges

在组件或者指令绑定的 @Input/@Output 属性发生变化的时候调用。需要注意的是如果输入属性绑定的是一个对象,那么只有这个对象的引用发生变化的时候才会调用

ngOnInit

只调用一次,用于初始化组件(对于一些复杂的初始化组件的逻辑应该放在这个里面而不是 constructor)。会在第一个的 ngOnChanges 调用完成之后调用,在这个生命周期中我们已经可以拿到@Input 属性绑定的值了

ngDoCheck

  • 每次变更检测(网络请求、事件、路由变化...)之后都会被调用

  • 状态发生变化,但是 angular 无法捕捉到这个变化的时候也会被调用

注意:这个生命周期会被频繁调用,所以不要写过于复杂的逻辑

ngAfterContentInit

在使用了并且 ng-content 中的内容初始化完成之后调用。我们可以在这个生命周期中访问到通过@ViewChild 选中的子组件

@ContentChild(ChildComponent) contentChild!: ChildComponent;

ngAfterContentChecked

在使用了并且 ng-content 中的内容初始化完成检测后调用,ngDoCheck 调用之后都会触发这个函数。

ngAfterViewInit

在组件以及其子组件初始化完成后会被调用。我们可以在这个生命周期中访问到通过@ViewChild 选中的子组件

@ViewChild(ChildViewComponent) viewChild!: ChildViewComponent;

ngAfterViewChecked

每次检查 compoent 页面或者它的子页面的时候执行,ngDoCheck 调用之后都会触发这个函数。

ngOnDestroy

在组件销毁之前调用,进行一些清理工作

Angular 在调用 AfterView 钩子之前,就已调用完所有的 AfterContent 钩子。 在完成该组件视图的合成之前, Angular 就已经完成了所投影内容的合成工作。 AfterContent... 和 AfterView... 钩子之间有一个小的时间窗,允许你修改宿主视图。

生命周期钩子需要注意的几点:

  • constructor vs ngOnInit

在 constructor 里并不是所有数据都已经存在,比如 @Input。所以建议需要使用输入属性的操作都放在 ngOnInit 中。

  • ngAfterContentXxx vs ngAfterViewXxx

前者跟对的是 ng-content 中的内容投影。后者针对的是当前组件以及其子组件的视图

  • ngOnChanges vs ngDoCheck

ngOnChanges 只有在输入属性的绑定发生变化的时候才会被执行,ngDoCheck 在每次 change detection 的时候都会触发或者是在状态发生变化 Angular 自己又不能捕获时被触发。所以在使用 ngDoCheck 的时候需要非常小心,里面的逻辑尽量精简,因为它会被频繁调用

你可能感兴趣的:(生命周期)