对Angular中的生命周期钩子的理解

什么是生命周期钩子

  简单点来讲生命周期钩子就是Angular中一个组件从被建立当销毁期间的一些有意义的关键时刻.这些关键时刻在Angular中被Angular核心模块@angular/core暴露出来,赋予了咱们在它们发生时采起行动的能力.bash

有哪些生命周期钩子

  Angular中从一个组件的建立到销毁一个有八个生命周期钩子它们,按照前后顺序.它们分别是:app

  • ngOnChanges()
  • ngOnInit()
  • ngDoCheck()
  • ngAfterContentInit()
  • ngAfterContentChecked()
  • ngAfterViewInit()
  • ngAfterViewChecked()
  • ngOnDestroy()

  其中:ngOnInit()ngAfterContentInit()ngAfterViewInit()ngOnDestroy()在一个组件的生命周期中只会被调用一次,其它的都有可能会被屡次调用.下面,就让咱们来详细解列一下这些生命周期钩子.异步

ngOnChanges()

  • 当Angular(从新)设置数据绑定输入属性时响应。 该方法接受当前和上一属性值的SimpleChanges对象
  • 当被绑定的输入属性的值发生变化时调用,首次调用必定会发生在ngOnInit()以前。

  ngOnChanges()生命周期的调用与一个组件中的输入属性有关.ui

  当在一个组件中使用@Input()定义了一个输入属性时.只要这个输入属性的值发生了改变.就会触发ngOnChanges()生命周期钩子.这个生命周期钩子被调用时会传入一个SimpleChanges对象,这个对象中包含了输入属性当前值和上一值.spa

@Input()
public name: string;

ngOnChanges(changes: SimpleChanges): void {
  console.log(changes); // name:SimpleChange {previousValue: "a", currentValue: "ab", firstChange: false}
}
复制代码

  上面是我定义了一个输入属性name并将从a它改成ab以后的打印结果,可能你还注意到了打印的结果中还有一个firstChange属性.它是一个Booleans,代表你是不是第一次改变.指针

   同时,还有一点须要注意: 你的输入属性定义为你引用类型和基本类型的时候其表现结果是不一样的.当你的输入属性是基本类型时.你的每一次改变都会触发ngOnChanges()生命周期钩子,而当你的输入属性是引用类型时,你改变你引用类型 当中 的属性时,并不会触发ngOnChanges()生命周期钩子.只有当你将你引用类型数据的指针指向另外一块内存地址的时候才会触发ngOnChanges()生命周期钩子.code

ngOnInit()

  • 在Angular第一次显示数据绑定和设置指令/组件的输入属性以后,初始化指令/组件。
  • 在第一轮ngOnChanges()完成以后调用,只调用一次。

  ngOnInit()是一个组件的生命周期中必定存在的一个钩子.它在一个组件被初始化的时候被调用.在这个期间,你能够执行一些相应的数据绑定操做.对象

ngDoCheck()

  • 检测,并在发生Angular没法或不肯意本身检测的变化时做出反应。
  • 在每一个Angular变动检测周期中调用,ngOnChanges()和ngOnInit()以后。

  ngDoCheck()是Angular中的变动检测机制.它由zone.js来实现的.其行为是只要你的Angular中的某个组件发生异步事件.就会检查整个组件树,以保证组件属性的变化或页面的变化是同步的.因此ngDoCheck()的触发至关频繁的.而且是咱们没法预料到的.也许咱们在页面上的一个无心识操做,就会触发几个甚至几十个的ngDoCheck()生命周期钩子.   因此咱们在使用ngDoCheck()生命周期钩子的时候必定要加上判断.以免无用的触发干扰咱们.生命周期

ngAfterContentInit()

  • 当把内容投影进组件以后调用。
  • 第一次ngDoCheck()以后调用,只调用一次。
  • 只适用于组件。

  当父组件向子组件投影内容的时.在子组件内会初始化父组件的投影内容,此时会调用ngAfterContentInit()生命周期钩子.在整个组件生命周期中ngAfterContentInit()生命周期钩子只会调用一次.以下所示:事件

// 父组件
<app-child>
  <p>我是父组件向子组件的投影内容</>
</app-child>


// 子组件 ChildComponent
<div>
  //接受父组件的投影内容
  <ng-content></ng-content>
</div>
复制代码

ngAfterContentChecked()

  • 每次完成被投影组件内容的变动检测以后调用。
  • ngAfterContentInit()和每次ngDoCheck()以后调用
  • 只适合组件。

  当父组件向子组件的投影内容发生改变时会调用ngAfterContentChecked()生命周期钩子.它与ngDoCheck()相似.当投影内容发生改变时,就会执行变动检查机制.同时调用ngAfterContentChecked()生命周期钩子.此外.还有一点:当父组件和子组件都有投影内容时,会先执行父组件的生命周期钩子.它与下面要说的ngAfterViewInit()ngAfterViewChecked()相反.

ngAfterViewInit()

  • 初始化完组件视图及其子视图以后调用。
  • 第一次ngAfterContentChecked()以后调用,只调用一次。
  • 只适合组件。

  当其组件自己和全部的子组件渲染完成,已经呈如今页面上时,调用ngAfterViewInit()生命周期钩子.在整个组件生命周期中ngAfterViewInit()生命周期钩子只会调用一次.

ngAfterViewChecked()

  • 每次作完组件视图和子视图的变动检测以后调用。
  • ngAfterViewInit()和每次ngAfterContentChecked()以后调用。
  • 只适合组件。

  当组件及其子组件的视图发生改变时,执行完变动检查机制后调用.当父组件和子组件都发生视图变化时,会先执行子组件的生命周期钩子.

  注意: 这里所说的视图发生改变不必定是真正页面上的变化.只是Angular种所认为的视图变化.由于Angular自己并不能察觉到页面上显示的视图.因此在Angular认为,只要你在后台定义的属性发生了改变,就是视图有了变化.从而就会调用ngAfterViewChecked()生命周期钩子.

ngOnDestroy

  • 当Angular每次销毁指令/组件以前调用并清扫。 在这儿反订阅可观察对象和分离事件处理器,以防内存泄漏。
  • 在Angular销毁指令/组件以前调用。

个人我的网址: wangyiming.info

相关文章
相关标签/搜索