docs(ajs-quick-reference): copy edits (#3297)

This commit is contained in:
Kapunahele Wong 2017-02-23 16:27:14 -05:00 committed by Jules Kremer
parent 710af93bdc
commit bc1b98d822
2 changed files with 76 additions and 55 deletions

View File

@ -13,7 +13,7 @@
"ajs-quick-reference": { "ajs-quick-reference": {
"title": "AngularJS to Angular Quick Reference", "title": "AngularJS to Angular Quick Reference",
"navTitle": "AngularJS to Angular", "navTitle": "AngularJS to Angular",
"intro": "Learn how AngularJS concepts and techniques map to Angular" "intro": "Learn how AngularJS concepts and techniques map to Angular."
}, },
"ngmodule-faq": { "ngmodule-faq": {

View File

@ -11,16 +11,16 @@ a(id="top")
**See the Angular syntax in this <live-example name="cb-ajs-quick-reference"></live-example>**. **See the Angular syntax in this <live-example name="cb-ajs-quick-reference"></live-example>**.
## Contents ## Contents
This page covers:
* [Template basics](#template-basics) - binding and local variables.
* [Template directives](#template-directives) - built-in directives `ngIf` and `ngClass`. * [Template basics](#template-basics)&mdash;binding and local variables.
* [Filters/pipes](#filters-pipes) - built-in *filters*, known as *pipes* in Angular. * [Template directives](#template-directives)&mdash;built-in directives `ngIf` and `ngClass`.
* [Modules/controllers/components](#controllers-components) - *modules* in Angular are slightly different from *modules* in AngularJS, and *controllers* are *components* in Angular. * [Filters/pipes](#filters-pipes)&mdash;built-in *filters*, known as *pipes* in Angular.
* [Style sheets](#style-sheets) - more options for CSS than in AngularJS. * [Modules/controllers/components](#controllers-components)&mdash;*modules* in Angular are slightly different from *modules* in AngularJS, and *controllers* are *components* in Angular.
* [Style sheets](#style-sheets)&mdash;more options for CSS than in AngularJS.
.l-main-section .l-main-section
:marked :marked
@ -59,7 +59,8 @@ table(width="100%")
The context of the binding is implied and is always the The context of the binding is implied and is always the
associated component, so it needs no reference variable. associated component, so it needs no reference variable.
For more information, see the [Interpolation](../guide/template-syntax.html#interpolation) section of the Template Syntax page. For more information, see the [Interpolation](../guide/template-syntax.html#interpolation)
section of the [Template Syntax](../guide/template-syntax.html) page.
tr(style=top) tr(style=top)
td td
:marked :marked
@ -79,7 +80,7 @@ table(width="100%")
Many (but not all) of the built-in filters from AngularJS are Many (but not all) of the built-in filters from AngularJS are
built-in pipes in Angular. built-in pipes in Angular.
For more information, see the heading [Filters/pipes](#filters-pipes) below. For more information, see [Filters/pipes](#filters-pipes) below.
tr(style=top) tr(style=top)
td td
:marked :marked
@ -97,7 +98,8 @@ table(width="100%")
:marked :marked
Angular has true template input variables that are explicitly defined using the `let` keyword. Angular has true template input variables that are explicitly defined using the `let` keyword.
For more information, see the [ngFor micro-syntax](../guide/template-syntax.html#ngForMicrosyntax) section of the Template Syntax page. For more information, see the [ngFor micro-syntax](../guide/template-syntax.html#microsyntax)
section of the [Template Syntax](../guide/template-syntax.html) page.
:marked :marked
[Back to top](#top) [Back to top](#top)
@ -172,7 +174,8 @@ table(width="100%")
Angular also has **class binding**, which is a good way to add or remove a single class, Angular also has **class binding**, which is a good way to add or remove a single class,
as shown in the third example. as shown in the third example.
For more information see the [Attribute, Class, and Style Bindings](../guide/template-syntax.html#other-bindings) section of the Template Syntax page. For more information see the [Attribute, class, and style bindings](../guide/template-syntax.html#other-bindings)
section of the [Template Syntax](../guide/template-syntax.html) page.
tr(style=top) tr(style=top)
td td
@ -190,7 +193,7 @@ table(width="100%")
to the controller. to the controller.
td td
:marked :marked
### bind to the `click` event ### Bind to the `click` event
+makeExample('cb-ajs-quick-reference/ts/src/app/app.component.html', 'event-binding')(format="." ) +makeExample('cb-ajs-quick-reference/ts/src/app/app.component.html', 'event-binding')(format="." )
:marked :marked
AngularJS event-based directives do not exist in Angular. AngularJS event-based directives do not exist in Angular.
@ -208,7 +211,8 @@ table(width="100%")
For a list of DOM events, see: https://developer.mozilla.org/en-US/docs/Web/Events. For a list of DOM events, see: https://developer.mozilla.org/en-US/docs/Web/Events.
For more information, see the [Event Binding](../guide/template-syntax.html#event-binding) section of the Template Syntax page. For more information, see the [Event binding](../guide/template-syntax.html#event-binding)
section of the [Template Syntax](../guide/template-syntax.html) page.
tr(style=top) tr(style=top)
td td
@ -238,7 +242,7 @@ table(width="100%")
an expression. For more information, see [ng-show](#ng-show). an expression. For more information, see [ng-show](#ng-show).
td td
:marked :marked
### bind to the `hidden` property ### Bind to the `hidden` property
In Angular, you use property binding; there is no built-in *hide* directive. In Angular, you use property binding; there is no built-in *hide* directive.
For more information, see [ng-show](#ng-show). For more information, see [ng-show](#ng-show).
tr(style=top) tr(style=top)
@ -259,18 +263,20 @@ table(width="100%")
Routing is handled differently in Angular. Routing is handled differently in Angular.
td td
:marked :marked
### bind to the `href` property ### Bind to the `href` property
+makeExample('cb-ajs-quick-reference/ts/src/app/app.component.html', 'href')(format="." ) +makeExample('cb-ajs-quick-reference/ts/src/app/app.component.html', 'href')(format="." )
:marked :marked
Angular, uses property binding; there is no built-in *href* directive. Angular uses property binding; there is no built-in *href* directive.
Place the element's `href` property in square brackets and set it to a quoted template expression. Place the element's `href` property in square brackets and set it to a quoted template expression.
For more information on property binding, see [Template Syntax](../guide/template-syntax.html#property-binding). For more information see the [Property binding](../guide/template-syntax.html#property-binding)
section of the [Template Syntax](../guide/template-syntax.html) page.
In Angular, `href` is no longer used for routing. Routing uses `routerLink`, as shown in the third example. In Angular, `href` is no longer used for routing. Routing uses `routerLink`, as shown in the following example.
+makeExample('cb-ajs-quick-reference/ts/src/app/app.component.html', 'router-link')(format="." ) +makeExample('cb-ajs-quick-reference/ts/src/app/app.component.html', 'router-link')(format="." )
:marked :marked
For more information on routing, see [Routing & Navigation](../guide/router.html#router-link). For more information on routing, see the [RouterLink binding](../guide/router.html#router-link)
section of the [Routing & Navigation](../guide/router.html) page.
tr(style=top) tr(style=top)
td td
@ -282,15 +288,16 @@ table(width="100%")
In AngularJS, the `ng-if` directive removes or recreates a portion of the DOM, In AngularJS, the `ng-if` directive removes or recreates a portion of the DOM,
based on an expression. If the expression is false, the element is removed from the DOM. based on an expression. If the expression is false, the element is removed from the DOM.
In this example, the `table` element is removed from the DOM unless the `movies` array has a length greater than zero. In this example, the `<table>` element is removed from the DOM unless the `movies` array has a length greater than zero.
td td
:marked :marked
### *ngIf ### *ngIf
+makeExample('cb-ajs-quick-reference/ts/src/app/movie-list.component.html', 'ngIf')(format="." ) +makeExample('cb-ajs-quick-reference/ts/src/app/movie-list.component.html', 'ngIf')(format="." )
:marked :marked
The `*ngIf` directive in Angular works the same as the `ng-if` directive in AngularJS. It removes or recreates a portion of the DOM based on an expression. The `*ngIf` directive in Angular works the same as the `ng-if` directive in AngularJS. It removes
or recreates a portion of the DOM based on an expression.
In this example, the `table` element is removed from the DOM unless the `movies` array has a length. In this example, the `<table>` element is removed from the DOM unless the `movies` array has a length.
The (*) before `ngIf` is required in this example. The (*) before `ngIf` is required in this example.
For more information, see [Structural Directives](../guide/structural-directives.html). For more information, see [Structural Directives](../guide/structural-directives.html).
@ -311,7 +318,9 @@ table(width="100%")
In Angular, **two-way binding** is denoted by `[()]`, descriptively referred to as a "banana in a box". This syntax is a shortcut for defining both property binding (from the component to the view) In Angular, **two-way binding** is denoted by `[()]`, descriptively referred to as a "banana in a box". This syntax is a shortcut for defining both property binding (from the component to the view)
and event binding (from the view to the component), thereby providing two-way binding. and event binding (from the view to the component), thereby providing two-way binding.
For more information on two-way binding with ngModel, see [Template Syntax](../guide/template-syntax.html#ngModel). For more information on two-way binding with `ngModel`, see the [NgModel&mdash;Two-way binding to
form elements with `[(ngModel)]`](../guide/template-syntax.html#ngModel)
section of the [Template Syntax](../guide/template-syntax.html) page.
tr(style=top) tr(style=top)
td td
:marked :marked
@ -322,14 +331,15 @@ table(width="100%")
In AngularJS, the `ng-repeat` directive repeats the associated DOM element In AngularJS, the `ng-repeat` directive repeats the associated DOM element
for each item in the specified collection. for each item in the specified collection.
In this example, the table row (`tr`) element repeats for each movie object in the collection of movies. In this example, the table row (`<tr>`) element repeats for each movie object in the collection of movies.
td td
:marked :marked
### *ngFor ### *ngFor
+makeExample('cb-ajs-quick-reference/ts/src/app/movie-list.component.html', 'ngFor')(format="." ) +makeExample('cb-ajs-quick-reference/ts/src/app/movie-list.component.html', 'ngFor')(format="." )
:marked :marked
The `*ngFor` directive in Angular is similar to the `ng-repeat` directive in AngularJS. It repeats the associated DOM element for each item in the specified collection. The `*ngFor` directive in Angular is similar to the `ng-repeat` directive in AngularJS. It repeats
More accurately, it turns the defined element (`tr` in this example) and its contents into a template and the associated DOM element for each item in the specified collection.
More accurately, it turns the defined element (`<tr>` in this example) and its contents into a template and
uses that template to instantiate a view for each item in the list. uses that template to instantiate a view for each item in the list.
Notice the other syntax differences: Notice the other syntax differences:
@ -350,21 +360,22 @@ table(width="100%")
In AngularJS, the `ng-show` directive shows or hides the associated DOM element, based on In AngularJS, the `ng-show` directive shows or hides the associated DOM element, based on
an expression. an expression.
In this example, the `div` element is shown if the `favoriteHero` variable is truthy. In this example, the `<div>` element is shown if the `favoriteHero` variable is truthy.
td td
:marked :marked
### bind to the `hidden` property ### Bind to the `hidden` property
+makeExample('cb-ajs-quick-reference/ts/src/app/movie-list.component.html', 'hidden')(format="." ) +makeExample('cb-ajs-quick-reference/ts/src/app/movie-list.component.html', 'hidden')(format="." )
:marked :marked
Angular, uses property binding; there is no built-in *show* directive. Angular uses property binding; there is no built-in *show* directive.
For hiding and showing elements, bind to the HTML `hidden` property. For hiding and showing elements, bind to the HTML `hidden` property.
To conditionally display an element, place the element's `hidden` property in square brackets and To conditionally display an element, place the element's `hidden` property in square brackets and
set it to a quoted template expression that evaluates to the *opposite* of *show*. set it to a quoted template expression that evaluates to the *opposite* of *show*.
In this example, the `div` element is hidden if the `favoriteHero` variable is not truthy. In this example, the `<div>` element is hidden if the `favoriteHero` variable is not truthy.
For more information on property binding, see [Template Syntax](../guide/template-syntax.html#property-binding). For more information on property binding, see the [Property binding](../guide/template-syntax.html#property-binding)
section of the [Template Syntax](../guide/template-syntax.html) page.
tr(style=top) tr(style=top)
td td
:marked :marked
@ -377,13 +388,14 @@ table(width="100%")
fetches from that URL. fetches from that URL.
td td
:marked :marked
### bind to the `src` property ### Bind to the `src` property
+makeExample('cb-ajs-quick-reference/ts/src/app/app.component.html', 'src')(format="." ) +makeExample('cb-ajs-quick-reference/ts/src/app/app.component.html', 'src')(format="." )
:marked :marked
Angular, uses property binding; there is no built-in *src* directive. Angular uses property binding; there is no built-in *src* directive.
Place the `src` property in square brackets and set it to a quoted template expression. Place the `src` property in square brackets and set it to a quoted template expression.
For more information on property binding, see [Template Syntax](../guide/template-syntax.html#property-binding). For more information on property binding, see the [Property binding](../guide/template-syntax.html#property-binding)
section of the [Template Syntax](../guide/template-syntax.html) page.
tr(style=top) tr(style=top)
td td
:marked :marked
@ -393,7 +405,7 @@ table(width="100%")
:marked :marked
In AngularJS, the `ng-style` directive sets a CSS style on an HTML element In AngularJS, the `ng-style` directive sets a CSS style on an HTML element
based on an expression. That expression is often a key-value control object with each based on an expression. That expression is often a key-value control object with each
key of the object defined as a CSS style name, and each value defined as an expression key of the object defined as a CSS property, and each value defined as an expression
that evaluates to a value appropriate for the style. that evaluates to a value appropriate for the style.
In the example, the `color` style is set to the current value of the `colorPreference` variable. In the example, the `color` style is set to the current value of the `colorPreference` variable.
@ -408,9 +420,11 @@ table(width="100%")
Angular also has **style binding**, which is good way to set a single style. This is shown in the second example. Angular also has **style binding**, which is good way to set a single style. This is shown in the second example.
For more information on style binding, see [Template Syntax](../guide/template-syntax.html#style-binding). For more information on style binding, see the [Style binding](../guide/template-syntax.html#style-binding) section of the
[Template Syntax](../guide/template-syntax.html) page.
For more information on the ngStyle directive, see [Template Syntax](../guide/template-syntax.html#ngStyle). For more information on the `ngStyle` directive, see [NgStyle](../guide/template-syntax.html#ngStyle)
section of the [Template Syntax](../guide/template-syntax.html) page.
tr(style=top) tr(style=top)
td td
:marked :marked
@ -452,7 +466,8 @@ table(width="100%")
The (*) before `ngSwitchCase` and `ngSwitchDefault` is required in this example. The (*) before `ngSwitchCase` and `ngSwitchDefault` is required in this example.
For more information on the ngSwitch directive, see [Template Syntax](../guide/template-syntax.html#ngSwitch). For more information, see [The NgSwitch directives](../guide/template-syntax.html#ngSwitch)
section of the [Template Syntax](../guide/template-syntax.html) page.
:marked :marked
[Back to top](#top) [Back to top](#top)
@ -460,7 +475,7 @@ a(id="filters-pipes")
.l-main-section .l-main-section
:marked :marked
## Filters/pipes ## Filters/pipes
Angular **pipes** provide formatting and transformation for data in our template, similar to AngularJS **filters**. Angular **pipes** provide formatting and transformation for data in the template, similar to AngularJS **filters**.
Many of the built-in filters in AngularJS have corresponding pipes in Angular. Many of the built-in filters in AngularJS have corresponding pipes in Angular.
For more information on pipes, see [Pipes](../guide/pipes.html). For more information on pipes, see [Pipes](../guide/pipes.html).
@ -477,7 +492,7 @@ table(width="100%")
code-example. code-example.
&lt;td>{{movie.price | currency}}&lt;/td> &lt;td>{{movie.price | currency}}&lt;/td>
:marked :marked
Formats a number as a currency. Formats a number as currency.
td td
:marked :marked
### currency ### currency
@ -622,15 +637,17 @@ table(width="100%")
... ...
}()); }());
:marked :marked
In AngularJS, you often defined an immediately invoked function expression (or IIFE) around your controller code. In AngularJS, an immediately invoked function expression (or IIFE) around controller code
This kept your controller code out of the global namespace. keeps it out of the global namespace.
td td
:marked :marked
### none ### none
You don't need to worry about this in Angular because you use ES 2015 modules This is a nonissue in Angular because ES 2015 modules
and modules handle the namespacing for you. handle the namespacing for you.
For more information on modules, see [Architecture Overview](../guide/architecture.html#module). For more information on modules, see the [Modules](../guide/architecture.html#modules) section of the
[Architecture Overview](../guide/architecture.html).
tr(style=top) tr(style=top)
td td
:marked :marked
@ -638,7 +655,8 @@ table(width="100%")
code-example. code-example.
angular.module("movieHunter", ["ngRoute"]); angular.module("movieHunter", ["ngRoute"]);
:marked :marked
In AngularJS, an Angular module keeps track of controllers, services, and other code. The second argument defines the list of other modules that this module depends upon. In AngularJS, an Angular module keeps track of controllers, services, and other code.
The second argument defines the list of other modules that this module depends upon.
td td
:marked :marked
### Angular modules ### Angular modules
@ -648,7 +666,7 @@ table(width="100%")
- `imports`: specifies the list of other modules that this module depends upon - `imports`: specifies the list of other modules that this module depends upon
- `declaration`: keeps track of your components, pipes, and directives. - `declaration`: keeps track of your components, pipes, and directives.
For more information on modules, see [Angular Modules](../guide/ngmodule.html). For more information on modules, see [Angular Modules (NgModule)](../guide/ngmodule.html).
tr(style=top) tr(style=top)
td td
:marked :marked
@ -660,23 +678,24 @@ table(width="100%")
["movieService", ["movieService",
MovieListCtrl]); MovieListCtrl]);
:marked :marked
AngularJS, has code in each controller that looks up an appropriate Angular module AngularJS has code in each controller that looks up an appropriate Angular module
and registers the controller with that module. and registers the controller with that module.
The first argument is the controller name. The second argument defines the string names of The first argument is the controller name. The second argument defines the string names of
all dependencies injected into this controller, and a reference to the controller function. all dependencies injected into this controller, and a reference to the controller function.
td td
:marked :marked
### Component Decorator ### Component decorator
+makeExample('cb-ajs-quick-reference/ts/src/app/movie-list.component.ts', 'component')(format=".") +makeExample('cb-ajs-quick-reference/ts/src/app/movie-list.component.ts', 'component')(format=".")
:marked :marked
Angular, adds a decorator to the component class to provide any required metadata. Angular adds a decorator to the component class to provide any required metadata.
The Component decorator declares that the class is a component and provides metadata about The `@Component` decorator declares that the class is a component and provides metadata about
that component such as its selector (or tag) and its template. that component such as its selector (or tag) and its template.
This is how you associate a template with code, which is defined in the component class. This is how you associate a template with logic, which is defined in the component class.
For more information, see the [Components](../guide/architecture.html#components) section of the Architecture Overview page. For more information, see the [Components](../guide/architecture.html#components)
section of the [Architecture Overview](../guide/architecture.html) page.
tr(style=top) tr(style=top)
td td
:marked :marked
@ -695,7 +714,8 @@ table(width="100%")
NOTE: If you are using TypeScript with AngularJS, you must use the `export` keyword to export the component class. NOTE: If you are using TypeScript with AngularJS, you must use the `export` keyword to export the component class.
For more information, see the [Components](../guide/architecture.html#components) section of the Architecture Overview page. For more information, see the [Components](../guide/architecture.html#components)
section of the [Architecture Overview](../guide/architecture.html) page.
tr(style=top) tr(style=top)
td td
:marked :marked
@ -719,7 +739,8 @@ table(width="100%")
This example injects a `MovieService`. This example injects a `MovieService`.
The first parameter's TypeScript type tells Angular what to inject, even after minification. The first parameter's TypeScript type tells Angular what to inject, even after minification.
For more information, see the [Dependency Injection](../guide/architecture.html#dependency-injection) section of the Architecture Overview. For more information, see the [Dependency injection](../guide/architecture.html#dependency-injection)
section of the [Architecture Overview](../guide/architecture.html).
:marked :marked
[Back to top](#top) [Back to top](#top)