深入了解Angular组件中的生命周期钩子


本文摘自PHP中文网,作者青灯夜游,侵删。

本篇文章带大家了解一下Angular组件生命周期钩子。有一定的参考价值,有需要的朋友可以参考一下,希望对大家有所帮助。

Angular 组件生命周期钩子


生命周期

其中,红色标记的生命周期钩子只调用一次,绿色部分会被反复调用,执行顺序依次由上而下。

ngOnChanges

当 Angular 设置数据绑定输入属性发生变化时响应,只对输入的不可变对象起作用。简单地讲就是,@Input 标记的属性发生变化的时候被调用,非 @Input 标记的属性改变不会调用 ngOnChanges。

ngOnInit

在第一次 ngOnChanges 执行之后调用,并且只被调用一次。它主要用于执行组件的其它初始化操作或获取组件输入的属性值。

ngDoCheck

组件的输入属性发生变化时,将会触发 ngDoCheck 方法,我们可以使用该方法,自定义我们的检测逻辑。【相关推荐:《angular教程》】

注意: 不要在 ngDoCheck 里面做非常复杂的事情,使用时要比较精准的定义检查位置,否则会造成性能问题。因为任何变化,比如鼠标的点击事件或键盘的输入事件都会触发 ngDoCheck。

变更检测

变更检测

变更检测策略

  • Default 策略
    当组件树中有任何一个组件发生改变时,整个组件树都会被检测一遍。

  • onPush 策略
    当一个组件发生改变时,如果其子组件使用的是 onPush 策略,则不会对其进行检测。只有在子组件的 @Input 输入属性发生改变时,才会进行检测。

ngAfterViewInit 和 ngAfterViewChecked

ngAfterViewInit 和 ngAfterViewChecked 钩子会在组件的模板的所有内容被装配完毕,组件的模板已经呈现给用户后被触发,装配过程是从子组件向父组件依次进行,而且 ngAfterViewInit 在 ngAfterViewChecked 之前被触发。

ngAfterViewInit 钩子只会在组件初始化完毕后被触发一次,而 ngAfterViewChecked 钩子在组件变更时都会被触发,所以此钩子的实现一定要精简,不然会引起性能问题。

在这两个钩子里面不能再修改组件上被绑定的属性,否则会抛出异常。

@ViewChild 装饰器和 ElementRef 元素参阅

在实际应用中,可通过这个两个元素获取视图层的 DOM 元素,对获取的 DOM 元素进行操作。

1

2

3

4

5

6

7

8

// .ts 文件中声明

@ViewChild('inputElem')

inputElem: ElementRef;

// 获取Dom元素的值

const value = this.inputElem.nativeElement.value;

 

// .html 文件中使用

<input nz-input type="text" #inputElem>

ngAfterContentInit 和 ngAfterContentChecked

这两个钩子是在投影内容装配完成之后执行的,而那个时候整个模板还没有装配完成,所以在这两个钩子里面可以修改被绑定的属性。

投影

在某些情况下,需要动态改变组件模板的内容,而这些内容没有复杂的业务逻辑,也不需要重用,只是一小部分 HTML 片段,这个时候可以使用 Angular 提供的一个特性,叫做投影。在 Angular 里面可以使用 ng-content 指令将父组件模板中的任意片段投影到它的子组件上。

需要注意的是,自定义的组件的标签内部是不可以嵌套其他标签的,它不像一般的 HTML 标签可以嵌套,但可以使用投影实现嵌套。

app.component.html

1

2

3

4

5

6

7

8

9

<div class="wrapper">

  <h1>我是父组件</h1>

  <div>这个 div 定义在父组件</div>

  <!-- 将要投影的内容写在子组件的标签之间 -->

  <app-child>

    <div class="header">这个是页头。这个 div 是父组件投影到子组件的。</div>

    <div class="footer">这个是页脚。</div>

  </app-child>

</div>

child.component.html

1

2

3

4

5

6

7

<div class="wrapper">

  <h1>这是子组件</h1>

  <!-- ng-content是投影点 -->

  <ng-content select=".header"></ng-content>

  <div>这个div定义在子组件中</div>

  <ng-content select=".footer"></ng-content>

</div>

其中,使用 select 属性可以实现针对性的内容投影。但是,需要注意的是,select 属性对应的值所指定的标签节点必须是组件下的直接子节点。否则,select属性无效。

ngAfterContentInit 和 ngAfterContentChecked 小结

  • ngAfterContentInit 和 ngAfterContentChecked 钩子在组件要投影的内容装配完毕以后才会被触发,ngAfterContentInit 在 ngAfterContentChecked 之前被触发。

  • 如果组件有子组件,父组件的这两个钩子先被触发,子组件的这两个钩子在父组件投影内容装配完毕后触发。

更多编程相关知识,请访问:编程入门!!

以上就是深入了解Angular组件中的生命周期钩子的详细内容,更多文章请关注木庄网络博客

相关阅读 >>

浅谈Angular中的模块(ngmodule),延迟加载模块

详解Angular中的依赖注入模式

Angular cli如果搭建Angular+typescript+material项目?

详解Angular中的observable(可观察对象)

浅谈一下Angular模板引擎ng-template

react中什么必须大写

浅谈Angular中导入本地json文件的方法

浅谈Angular中的component/service

16个值得收藏的Angular ui框架分享

浅谈Angular如何借助第三方组件和懒加载技术进行性能优化

更多相关阅读请进入《Angular》频道 >>




打赏

取消

感谢您的支持,我会继续努力的!

扫码支持
扫码打赏,您说多少就多少

打开支付宝扫一扫,即可进行扫码打赏哦

分享从这里开始,精彩与您同在

评论

管理员已关闭评论功能...