2016-02-06 02:27:06 -05:00
|
|
|
include ../_util-fns
|
2015-11-21 14:23:40 -05:00
|
|
|
|
|
|
|
:marked
|
|
|
|
# Component Lifecycle
|
|
|
|
A Component has a lifecycle managed by Angular itself. Angular creates it, renders it, creates and renders its children,
|
|
|
|
checks it when its data-bound properties change, and destroys it before removing it from the DOM.
|
2016-01-13 04:41:16 -05:00
|
|
|
|
2015-11-21 14:23:40 -05:00
|
|
|
Angular offers **Lifecycle hooks**
|
|
|
|
that give us visibility into these key moments and the ability to act when they occur.
|
2016-01-13 04:41:16 -05:00
|
|
|
|
2015-11-21 14:23:40 -05:00
|
|
|
We cover these hooks in this chapter and demonstrate how they work in code.
|
2016-01-13 04:41:16 -05:00
|
|
|
|
2015-11-21 14:23:40 -05:00
|
|
|
[Live Example](/resources/live-examples/lifecycle-hooks/ts/plnkr.html)
|
2016-01-13 04:41:16 -05:00
|
|
|
|
2015-11-21 14:23:40 -05:00
|
|
|
<!--
|
|
|
|
https://github.com/angular/angular/blob/master/modules/angular2/src/core/linker/interfaces.ts
|
|
|
|
-->
|
|
|
|
|
|
|
|
.l-main-section
|
|
|
|
:marked
|
|
|
|
## The Lifecycle Hooks
|
|
|
|
Directive and component instances have a lifecycle
|
|
|
|
as Angular creates, updates, and destroys them.
|
2016-01-13 04:41:16 -05:00
|
|
|
|
2015-11-21 14:23:40 -05:00
|
|
|
Developers can tap into key moments in that lifecycle by implementing
|
|
|
|
one or more of the "Lifecycle Hook" interfaces, all of them available
|
2016-01-13 04:41:16 -05:00
|
|
|
in the `angular2/core` library.
|
|
|
|
|
2015-11-21 14:23:40 -05:00
|
|
|
Here is the complete lifecycle hook interface inventory:
|
|
|
|
|
|
|
|
* `OnInit`
|
|
|
|
* `OnDestroy`
|
|
|
|
* `DoCheck`
|
|
|
|
* `OnChanges`
|
|
|
|
* `AfterContentInit`
|
|
|
|
* `AfterContentChecked`
|
|
|
|
* `AfterViewInit`
|
|
|
|
* `AfterViewChecked`
|
|
|
|
|
|
|
|
No directive or component will implement all of them and some of them only make
|
|
|
|
sense for components.
|
2016-01-13 04:41:16 -05:00
|
|
|
|
2015-11-21 14:23:40 -05:00
|
|
|
Each interface has a single hook method whose name is the interface name prefixed with `ng`.
|
2016-01-13 04:41:16 -05:00
|
|
|
For example, the `OnInit` interface has a hook method named `ngOnInit`.
|
|
|
|
|
2015-11-21 14:23:40 -05:00
|
|
|
Angular calls these hook methods in the following order:
|
|
|
|
* `ngOnChanges` - called when an input or output binding value changes
|
|
|
|
* `ngOnInit` - after the first `ngOnChanges`
|
|
|
|
* `ngDoCheck` - developer's custom change detection
|
|
|
|
* `ngAfterContentInit` - after component content initialized
|
|
|
|
* `ngAfterContentChecked` - after every check of component content
|
|
|
|
* `ngAfterViewInit` - after component's view(s) are initialized
|
|
|
|
* `ngAfterViewChecked` - after every check of a component's view(s)
|
|
|
|
* `ngOnDestroy` - just before the directive is destroyed.
|
2016-01-13 04:41:16 -05:00
|
|
|
|
2015-11-21 14:23:40 -05:00
|
|
|
The [live example](/resources/live-examples/lifecycle-hooks/ts/plnkr.html) demonstrates
|
|
|
|
these hooks.
|
|
|
|
|
|
|
|
:marked
|
|
|
|
## Peek-a-boo
|
|
|
|
The `PeekABooComponent` demonstrates all of the hooks in the same component.
|
|
|
|
.l-sub-section
|
|
|
|
:marked
|
|
|
|
Except for `DoCheck`. If our component superseded regular Angular change detection
|
|
|
|
with its own change detection processing
|
|
|
|
we would also add a `ngDoCheck` method. We would **not** implement `ngOnChanges`.
|
|
|
|
We write either `ngOnChanges` or `ngDoCheck`, not both.
|
2016-01-13 04:41:16 -05:00
|
|
|
|
|
|
|
Custom change detection and `ngDoCheck` are on our documentation backlog.
|
2015-11-21 14:23:40 -05:00
|
|
|
:marked
|
|
|
|
Peek-a-boo is a demo. We'd rarely if ever implement all interfaces like this in real life.
|
|
|
|
|
|
|
|
We look forward to explaining the Peek-a-boo example and the other lifecycle hook examples in
|
2016-01-13 04:41:16 -05:00
|
|
|
an update to this chapter. Meanwhile, please enjoy poking around in the
|
2015-11-21 14:23:40 -05:00
|
|
|
[code](/resources/live-examples/lifecycle-hooks/ts/plnkr.html).
|
2016-01-13 04:41:16 -05:00
|
|
|
|
2015-11-21 14:23:40 -05:00
|
|
|
## Interface optional?
|
|
|
|
The lifecycle interfaces are optional.
|
2016-01-13 04:41:16 -05:00
|
|
|
We recommend adding them to benefit from TypeScript's strong typing and editor tooling.
|
|
|
|
|
|
|
|
But they disappear from the transpiled JavaScript.
|
2015-11-21 14:23:40 -05:00
|
|
|
Angular can't see them at runtime. And they are useless to someone developing in
|
|
|
|
a language without interfaces (such as pure JavaScript).
|
2016-01-13 04:41:16 -05:00
|
|
|
|
|
|
|
Fortunately, they aren't necessary.
|
2015-11-21 14:23:40 -05:00
|
|
|
We don't have to add the lifecycle hook interfaces to our directives and components to benefit from the hooks themselves.
|
2016-01-13 04:41:16 -05:00
|
|
|
|
2015-11-21 14:23:40 -05:00
|
|
|
Angular instead inspects our directive and component classes
|
|
|
|
and calls the hook methods *if they are defined*.
|
2016-01-13 04:41:16 -05:00
|
|
|
Angular will find and call methods like `ngOnInit()`, with or without the interfaces.
|