【Angular】生命周期钩子

前言

每个组件都有被Angular管理的生命周期。
Angular 提供了生命周期钩子,把这些关键生命时刻暴露出来,赋予你在它们发生时采取行动的能力。

组件生命周期

  • 红色之调用一次,蓝色可多次调用
    在这里插入图片描述
  • 指令和组件的实例有一个生命周期:新建、更新和销毁。
ngOnChanges()
  • 当Angular设置数据绑定输入属性发生变化时响应。
  • 时机:当被绑定的输入属性的值发生变化时调用,不过首次调用是会发生在ngOnInit()之前的。
    ngOnChanges()方法获取了一个对象,它可以同时观测1个/多个绑定的属性值,它把每个发生变化的属性名都映射到了一个SimpleChange对象, 该对象中有属性的当前值和前一个值。
ngOnInit()
  • 在Angular第一次显示数据绑定和设置指令/组件的输入属性之后,初始化指令/组件。
  • 时机:在第一轮ngOnChanges()完成之后调用,只调用一次。
    要明确一点就是,虽然接口中有一个constructor构造函数,但是在这里最好只对局部变量进行初始化之外什么都不做,通过ngOnInit()获取初始数据,而且是放在构造函数后面。
ngDoCheck()[慎用]
  • 检测那些Angular自身无法捕获的变更
  • 时机:在每个Angular变更检测周期中调用,ngOnChanges()和ngOnInit()之后。
    谨慎使用,因为一些你意想不到的事情也会被视为变更了
ngAfterContentInit()
  • 在外来内容被投影到组件中之后/投影组件内容的变更检测之后调用
  • 时机: ngAfterContentInit()–第一次ngDoCheck()之后调用,且只调用一次;
ngAfterContentChecked()[慎用]

只适用于组件

  • 在外来内容被投影到组件中之后/投影组件内容的变更检测之后调用
  • 时机: ngAfterContentChecked()–每次ngDoCheck()之后调用,如果需要调用ngAfterContentInit(),则在ngAfterContentInit()调用之后
ngAfterViewInit()和ngAfterViewChecked()[慎用]

只适用于组件

  • 初始化完/检测变更完组件视图及其子视图之后调用。
  • 时机:跟相应的content钩子类似,在对应的content钩子后面。
ngOnDestroy()
  • 反订阅可观察对象和分离事件处理器,以防内存泄漏
  • 时机:销毁指令/组件之前调用并清扫
    释放那些不会被垃圾收集器自动回收的各类资源的地方。取消那些对可观察对象和DOM事件的订阅。停止定时器。注销该指令曾注册到全局服务或应用级服务中的各种回调函数。
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 6
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 6
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值