Angular 5.x Lifecycle Hooks Learn Note

Angular 5.x 生命周期钩子学习笔记

标签(空格分隔): Angular

Note on cnblogs.com


3. 生命周期钩子

每个组件都有一个被ng管理的生命周期。

1. 组件生命周期钩子概览

指令和组件的实例都有一个生命周期钩子:新建、更新和销毁。
生命周期钩子接口在core库中。
每个生命周期钩子接口都有唯一的钩子方法,它们的命名是加ng前缀。

2. 生命周期的顺序
钩子 目的和时机
ngOnChanges() 当ng(重新)设置数据绑定输入属性时响应。该方法接受当前各上一属性值的SimpleChanges对象。
当被绑定的输入属性的值发生变化时调用,首次调用一定会发生在bgOnInit()之前。
ngOnInit() 在Angular第一次显示数据绑定和设置指令/组件的输入属性之后,初始化指令/组件。
在第一轮ngOnChanges()完成之后调用,只调用一次。
ngDoCheck() 检测,并在发生Angular无法或不愿意自己检测的变化时做出反应。
在每个Angular变更检测周期中调用,ngOnChanges()ngOnInit()之后。
ngAfterContentInit() 当把内容投影进组件之后调用。
第一次ngDoCheck()之后调用,只调用一次。
只适用于组件。
ngAfterContentChecked() 每次完成被投影组件内容的变更检测之后调用 。
ngAfterContentInit()和每次ngDoCheck()之后调用。
只适合组件。
ngAfterViewInit() 初始化完组件视图及其子视图之后调用。
第一次ngAfterContentChecked()之后调用,只调用一次。
只适合组件。
ngAfterViewChecked 每次做完组件视图和子视图的变更检测之后调用。
ngAfterViewInit()ngAfterContentChecked()之后调用。
只适合组件。
ngOnDestroy 当Angular每次销毁指令/组件之前调用并清扫。在这反订阅可观察对象和分离事件处理器,以防内存泄露。
在Angular销毁指令/组件之前调用。
3. 接口是可选的

建议在TypeScript指令类中添加接口。

Angular的其它子系统除了有这些组件钩子外,还可能有他们自己的生命周期钩子,第三方库也可能会实现他们自己的钩子。

4. 生命周期练习

| 组件 | 描述 |
|: ------ |: ----- |
| Peek-a-boo | 展示每个生命周期钩子,每个钩子方法都会在屏幕上显示一条日志 |
| Spy | 指令同样有生命周期钩子,我们新建了一个SpyDirective,利用ngOnInitngOnDestroy钩子,在它所监视的每个元素被创建或销毁时输出日志。
本例把SpyDirective应用到父组件里的ngFor英雄重复器(repeater)的<div>里面。 |
| OnChanges | 这里将会看到:每当组件的输入属性发生变化时,Angular会如何以changes对象作为参数去调用ngOnChanges()钩子。展示了该如何理解和使用changes对象。 |
| DoCheck | 实现了一个ngDoCheck方法,它可以自定义变更检测逻辑。这里将会看到:Angular会用什么频度调用这个钩子,监视它的变化,并把这些变化输出成一条日志。|
| AfterView | 显示Anglar中的视图所指的是什么。演示了ngAfterViewInitngAfterViewChecked钩子。 |
| AfterContent | 展示如歌把外部内容投影进组件中,以及如何区分“投影进来的内容”和“组件的子视图”。演示了ngAfterContentInitngAfterContentChecked钩子。 |
| 计数器 | 演示了组件和指令的组合,他们各自有自己的钩子。在这个例子中,每当父组件递增它的输入属性counter时,CounterComponent就会通过ngOnChanges记录一条变更。同时,我们还把前一个例子中的SpyDirective用在ConterComponent上,来提供日志,可以同时观察到日志的创建和销毁过程。|

4.1 Peek-a-boo:全部钩子

PeekABooComponent组件演示了组件中所有可能存在的钩子。

  • OnInit和OnDestroy

    • 就像对组件一样,Angular也会对指令调用这些钩子方法。
    • 一个侦探(SPY)指令可以让我们在无法直接修改DOM对象实现代码的情况下,透视其内部细节。显然,你不能修改一个原生<div>元素的实现代码,你同样不能修改第三方组件。但我们用一个指令就能监视它们了。

    侦探指令基本由ngOnInit()ngOnDestroy钩子组成,它通过一个注入进来的LoggerService来把消息记录到父组件中去。

Angular 5.x 学习笔记(2) - 生命周期钩子 - 暂时搁浅的更多相关文章

  1. AngularJs学习笔记-组件生命周期

    组件生命周期 (1)组件生命周期钩子 constructor:组件创建时被创建 ngOnChanges: 父组件修改或初始化子组件的输入属性时被调用,如果子组件没有输入属性,则永远不会被调用,它的首次 ...

  2. Vue2学习笔记:实例生命周期

    实例生命周期 每个 Vue 实例在被创建之前都要经过一系列的初始化过程.例如,实例需要配置数据观测(data observer).编译模版.挂载实例到 DOM ,然后在数据变化时更新 DOM .在这个 ...

  3. VUE 学习笔记 二 生命周期

    1.除了数据属性,Vue 实例还暴露了一些有用的实例属性与方法.它们都有前缀 $,以便与用户定义的属性区分开来 var data = { a: 1 } var vm = new Vue({ el: ' ...

  4. Java Web学习笔记-Servle生命周期

    Servlet会在服务器启动或第一次请求该Servlet的时候开始生命周期,在服务器停止的时候结束生命周期. 无论请求多少次Servlet,最多只有一个Servlet实例.多个客户端并发请求Servl ...

  5. android学习笔记 activity生命周期&任务栈&activity启动模式

    activity生命周期 完整生命周期 oncreate->onstart->onresume->onpause->onstop->ondestory 使用场景:应用程序 ...

  6. iOS学习笔记—ViewController/生命周期

    ViewController是iOS应用程序中重要的部分,是应用程序数据和视图之间的重要桥梁,ViewController管理应用中的众多视图.iOS的SDK中提供很多原生ViewController ...

  7. MVC学习笔记---MVC生命周期

    Asp.net应用程序管道处理用户请求时特别强调"时机",对Asp.net生命周期的了解多少直接影响我们写页面和控件的效率.因此在2007年和2008年我在这个话题上各写了一篇文章 ...

  8. MVC学习笔记---MVC生命周期及管道

    ASP.NET和ASP.NET MVC的HttpApplication请求处理管道有共同的部分和不同之处,本系列将体验ASP.NET MVC请求处理管道生命周期的19个关键环节. ①以IIS6.0为例 ...

  9. Android学习笔记_18_Activity生命周期 及 跳转方式

    一.Activity有三个状态: 1.当它在屏幕前台时(位于当前任务堆栈的顶部),它是激活或运行状态.它就是响应用户操作的Activity. 2. 当它上面有另外一个Activity,使它失去了焦点但 ...

随机推荐

  1. docker容器启动几分钟之后自动退出

    2018-11-06 问题: docker容器启动几分钟之后自动退出 log日志报错 WARNING: overlay2: the backing xfs filesystem is formatte ...

  2. linux 第八章 高级键盘

    1.clear:清屏 2.history:显示历史命令列表 3.Ctrl+A:移动光标到行首 4.Ctrl+E:移动光标到行尾 5.Ctrl+F:光标向前移动一个字符 6.Ctrl+B:光标向h后移动 ...

  3. python_学生信息管理实例

    """提示:代码中的内容均被注释,请参考,切勿照搬""" """注意:代码切勿照搬,错误请留言指出" ...

  4. Oracle 的加减法函数

    原文:https://blog.csdn.net/chenghaibing2008/article/details/37873117 加法   select sysdate,add_months(sy ...

  5. TimesTen启动停止命令

    ttDaemonAdmin –start 启动 ttDaemonAdmin –stop 停止 或打开服务cmd-serviers.msc,找到相关服务启动或停止.

  6. angular的基本要点

    <body ng-app="Myapp"> <div ng-controller="firstcon"> <h1>hello ...

  7. 数据库~大叔通过脚本生成poco实体

    今天在做开发时,需要把表映射成实体,又没有EF这种工具,就从网上下了一个工具,但使用时觉得太重了,所以就自己写了一个,基于mysql的. 功能:输入表名,得到这个表的poco实体 SELECT COL ...

  8. 游戏源码--Unity开源Moba游戏-服务器-客户端完整V1.0

    http://www.manew.com/thread-111658-1-1.html

  9. windows使用bat文件定时备份文件

    遇到一个需求,需要备份Access数据库,Access生成的数据都保存在xx.mdb文件中,所以考虑使用windows任务 定时执行一个备份文件的bat文件来解决这个问题. backup.bat文件代 ...

  10. MVC Request.UrlReferrer为null

    使用情景,登录后返回登录前访问的页面. 这个时候用到了UrlReferrer var returnUrl = HttpContext.Current.Request.UrlReferrer != nu ...