Angular 5.x 学习笔记(2) - 生命周期钩子 - 暂时搁浅
Angular 5.x Lifecycle Hooks Learn Note
Angular 5.x 生命周期钩子学习笔记
标签(空格分隔): Angular
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
,利用ngOnInit
和ngOnDestroy
钩子,在它所监视的每个元素被创建或销毁时输出日志。
本例把SpyDirective
应用到父组件里的ngFor
英雄重复器(repeater)的<div>
里面。 |
| OnChanges
| 这里将会看到:每当组件的输入属性发生变化时,Angular会如何以changes
对象作为参数去调用ngOnChanges()
钩子。展示了该如何理解和使用changes
对象。 |
| DoCheck
| 实现了一个ngDoCheck
方法,它可以自定义变更检测逻辑。这里将会看到:Angular会用什么频度调用这个钩子,监视它的变化,并把这些变化输出成一条日志。|
| AfterView
| 显示Anglar中的视图所指的是什么。演示了ngAfterViewInit
和ngAfterViewChecked
钩子。 |
| AfterContent
| 展示如歌把外部内容投影进组件中,以及如何区分“投影进来的内容”和“组件的子视图”。演示了ngAfterContentInit
和ngAfterContentChecked
钩子。 |
| 计数器 | 演示了组件和指令的组合,他们各自有自己的钩子。在这个例子中,每当父组件递增它的输入属性counter
时,CounterComponent
就会通过ngOnChanges
记录一条变更。同时,我们还把前一个例子中的SpyDirective
用在ConterComponent
上,来提供日志,可以同时观察到日志的创建和销毁过程。|
4.1 Peek-a-boo:全部钩子
PeekABooComponent
组件演示了组件中所有可能存在的钩子。
OnInit和OnDestroy
- 就像对组件一样,Angular也会对指令调用这些钩子方法。
- 一个侦探(SPY)指令可以让我们在无法直接修改DOM对象实现代码的情况下,透视其内部细节。显然,你不能修改一个原生
<div>
元素的实现代码,你同样不能修改第三方组件。但我们用一个指令就能监视它们了。
侦探指令基本由
ngOnInit()
和ngOnDestroy
钩子组成,它通过一个注入进来的LoggerService
来把消息记录到父组件中去。
Angular 5.x 学习笔记(2) - 生命周期钩子 - 暂时搁浅的更多相关文章
- AngularJs学习笔记-组件生命周期
组件生命周期 (1)组件生命周期钩子 constructor:组件创建时被创建 ngOnChanges: 父组件修改或初始化子组件的输入属性时被调用,如果子组件没有输入属性,则永远不会被调用,它的首次 ...
- Vue2学习笔记:实例生命周期
实例生命周期 每个 Vue 实例在被创建之前都要经过一系列的初始化过程.例如,实例需要配置数据观测(data observer).编译模版.挂载实例到 DOM ,然后在数据变化时更新 DOM .在这个 ...
- VUE 学习笔记 二 生命周期
1.除了数据属性,Vue 实例还暴露了一些有用的实例属性与方法.它们都有前缀 $,以便与用户定义的属性区分开来 var data = { a: 1 } var vm = new Vue({ el: ' ...
- Java Web学习笔记-Servle生命周期
Servlet会在服务器启动或第一次请求该Servlet的时候开始生命周期,在服务器停止的时候结束生命周期. 无论请求多少次Servlet,最多只有一个Servlet实例.多个客户端并发请求Servl ...
- android学习笔记 activity生命周期&任务栈&activity启动模式
activity生命周期 完整生命周期 oncreate->onstart->onresume->onpause->onstop->ondestory 使用场景:应用程序 ...
- iOS学习笔记—ViewController/生命周期
ViewController是iOS应用程序中重要的部分,是应用程序数据和视图之间的重要桥梁,ViewController管理应用中的众多视图.iOS的SDK中提供很多原生ViewController ...
- MVC学习笔记---MVC生命周期
Asp.net应用程序管道处理用户请求时特别强调"时机",对Asp.net生命周期的了解多少直接影响我们写页面和控件的效率.因此在2007年和2008年我在这个话题上各写了一篇文章 ...
- MVC学习笔记---MVC生命周期及管道
ASP.NET和ASP.NET MVC的HttpApplication请求处理管道有共同的部分和不同之处,本系列将体验ASP.NET MVC请求处理管道生命周期的19个关键环节. ①以IIS6.0为例 ...
- Android学习笔记_18_Activity生命周期 及 跳转方式
一.Activity有三个状态: 1.当它在屏幕前台时(位于当前任务堆栈的顶部),它是激活或运行状态.它就是响应用户操作的Activity. 2. 当它上面有另外一个Activity,使它失去了焦点但 ...
随机推荐
- poj1182 食物链 带权并查集
题目传送门 题目大意:大家都懂. 思路: 今天给实验室的学弟学妹们讲的带权并查集,本来不想细讲的,但是被学弟学妹们的态度感动了,所以写了一下这个博客,思想在今天白天已经讲过了,所以直接上代码. 首先, ...
- dataTable 加了竖向滚动条导致列头样式错位的问题 / 亲测可用,不好用你打我,用好了记得点推荐
tab在没有显示之前,容器是没有高度宽度的,而dt在自动计算高度和宽度时是获取的外部容器的高度和宽度,当切换tab时,dt获取不到这个高度宽度,导致列头都挤在一起,是用下面代码解决此问题 $('a[d ...
- 挑战程序设计竞赛 P131 区间DP
书上好多题没补 PS.整个DP是根据Q来划分的,dalao的代码就是不一样啊 #include<bits/stdc++.h> #define rep(i,j,k) for(int i=j; ...
- Action执行时间过滤器
public class AccessStatisticsAttribute : ActionFilterAttribute { /// <summary> /// log4net 日志 ...
- Oracle之AUTHID CURRENT_USER
没有AUTHID CURRENT_USER表示定义者权限(definer rights),以定义者身份执行: 加上AUTHID CURRENT_USER表示调用者权限(invoker rights), ...
- CI 框架中的日志处理 以及 404异常处理
最近在整理项目中的日志问题,查了一些关于 “CI 框架中的日志处理 以及 404异常处理” 的东西,顺便记录一下: 关于错误日志: 1. 在CI框架中的 system/core/CodeIgniter ...
- APP在用户设备发生crash,应该怎么修复
Crash原因 Crash原因有共性,归纳起来有: 内存管理错误 程序逻辑错误 SDK错误 (部署版本< 编译版本) 主线程阻塞 内存管理错误 内存管理是iPhone开发所要掌握的最基本问题, ...
- matplotlib中绘图配色
Python中绘图配色(参照博文: Python-画图(散点图scatter.保存savefig)及颜色大全) # 可以直接使用配色编码 c=["#A52A2A" if tag = ...
- Java基础26-对象初始化过程
/* 1.因为new Test1()用到了Test1类,所以会把它从硬盘上加载进入内存 2.如果有static静态代码块就会随着类的加载而执行,还有静态成员和普通方法也会随着类的加载而被加载 3.在堆 ...
- 2018最新mfc作为上位机接收硬件端USB或串口数据显示成图片 解决串口接收数据丢字节丢包问题
原文作者:aircraft 原文地址:https://www.cnblogs.com/DOMLX/p/9490616.html 本文用的是VS2013MFC写串口数据接收: 第一步:首先建立一个MFC ...