生命周期和钩子函数
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></ng-content>
并且 ng-content 中的内容初始化完成之后调用。我们可以在这个生命周期中访问到通过@ViewChild 选中的子组件
@ContentChild(ChildComponent) contentChild!: ChildComponent;
ngAfterContentChecked
在使用了<ng-content></ng-content>
并且 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 的时候需要非常小心,里面的逻辑尽量精简,因为它会被频繁调用
网友评论