docs(core/templates): fix various typo and grammatical errors

Closes #666
This commit is contained in:
Richard Harrington 2015-02-15 22:06:53 -05:00 committed by Misko Hevery
parent 81bc706ef1
commit a002ed1183
1 changed files with 26 additions and 17 deletions

View File

@ -1,19 +1,20 @@
# Templates # Templates
Templates are markup which is added to HTML to declarativly describe how the application model should be Templates are markup which is added to HTML to declaratively describe how the application model should be
projected to DOM as well as which DOM events should invoke which methods on the controller. Templates contain projected to DOM as well as which DOM events should invoke which methods on the controller. Templates contain
syntax which is core to Angular and allows for data-binding, event-binding, template-instantiation. syntax which is core to Angular and allows for data-binding, event-binding, template-instantiation.
The design of the template syntax has these properties: The design of the template syntax has these properties:
* All data-binding expressions are easily identifiable. (i.e. there is never an ambiguity whether the value should be * All data-binding expressions are easily identifiable. (i.e. there is never an ambiguity whether the value should be
interpreted as string literal or as an expression.) interpreted as string literal or as an expression.)
* All events and their statements are easily identifiable. * All events and their statements are easily identifiable.
* All places of DOM instantiation are easily identifiable. * All places of DOM instantiation are easily identifiable.
* All places of variable declaration is easily identifiable. * All places of variable declaration are easily identifiable.
The above properties guarantee that the templates are easily to be parsed by tools (such as IDEs) and reasoned about by people. The above properties guarantee that the templates are easy to parse by tools (such as IDEs) and reason about by people.
At no point is it necessary to understand which directives are active and what are their semantics in order to reason At no point is it necessary to understand which directives are active or what their semantics are in order to reason
about the template runtime characteristics. about the template runtime characteristics.
@ -222,7 +223,11 @@ Example:
## Property Binding ## Property Binding
<<<<<<< HEAD
Binding application model data to the UI is the most common kind of bindings in an Angular application. The bindings Binding application model data to the UI is the most common kind of bindings in an Angular application. The bindings
=======
Binding application model data to the UI is the most common type of binding in an Angular application. The bindings
>>>>>>> upstream/pr/666
are always in the form of `property-name` which is assigned an `expression`. The generic form is: are always in the form of `property-name` which is assigned an `expression`. The generic form is:
<table> <table>
@ -253,7 +258,11 @@ its value.
Key points: Key points:
* The binding is to the element property not the element attribute. * The binding is to the element property not the element attribute.
<<<<<<< HEAD
* To prevent custom element from accidentally reading the literal `expression` on the title element, the attribute name * To prevent custom element from accidentally reading the literal `expression` on the title element, the attribute name
=======
* To prevent a custom element from accidentally reading the literal `expression` on the title element, the attribute name
>>>>>>> upstream/pr/666
is escaped. In our case the `title` is escaped to `[title]` through the addition of square brackets `[]`. is escaped. In our case the `title` is escaped to `[title]` through the addition of square brackets `[]`.
* A binding value (in this case `user.firstName` will always be an expression, never a string literal) * A binding value (in this case `user.firstName` will always be an expression, never a string literal)
@ -345,10 +354,10 @@ Where:
inserted. The template can be defined implicitly with `template` attribute, which turns the current element into inserted. The template can be defined implicitly with `template` attribute, which turns the current element into
a template, or explicitly with `<template>` element. Explicit declaration is longer, but it allows for having a template, or explicitly with `<template>` element. Explicit declaration is longer, but it allows for having
templates which have more than one root DOM node. templates which have more than one root DOM node.
* `instantiating-directive` is required for templates. The instantiating directive is responsible for deciding when * `viewport` is required for templates. The Viewport directive is responsible for deciding when
and in which order should child views be inserted into this location. An instantiating directive usually has one or and in which order should child views be inserted into this location. An Viewport directive usually has one or
more bindings and can be represented as either `instantiating-directive-bindings` or more bindings and can be represented as either `viewport-directive-bindings` or
`instantiating-directive-microsyntax` on `template` element or attribute. See template microsyntax for more details. `viewport-directive-microsyntax` on `template` element or attribute. See template microsyntax for more details.
Example of conditionally included template: Example of conditionally included template:
@ -360,7 +369,7 @@ Hello {{user}}!
</div> </div>
``` ```
In the above example the `if` instantiator determines whether the child view (an instance of the child template) should be In the above example the `if` Viewport determines whether the child view (an instance of the child template) should be
inserted into the root view. The `if` makes this decision based on if the `isAdministrator` binding is true. inserted into the root view. The `if` makes this decision based on if the `isAdministrator` binding is true.
The above example is in the short form, for better clarity let's rewrite it in the canonical form, which is functionally The above example is in the short form, for better clarity let's rewrite it in the canonical form, which is functionally
@ -375,7 +384,7 @@ Hello {{user}}!
</template> </template>
``` ```
NOTE: Only Instantiator directives can be placed on the template element. (Decorators and Components are not allowed.) NOTE: Only Viewport directives can be placed on the template element. (Decorators and Components are not allowed.)
### Template Microsyntax ### Template Microsyntax
@ -395,11 +404,11 @@ of the templates occurs. One such example is `foreach`.
Where: Where:
* `foreach` triggers the foreach directive. * `foreach` triggers the foreach directive.
* `[in]="people"` binds to an iterable object to the `foreach` controller. * `[in]="people"` binds an iterable object to the `foreach` controller.
* `#person` exports the implicit `foreach` item. * `#person` exports the implicit `foreach` item.
* `#i=index` exports item index as `i`. * `#i=index` exports item index as `i`.
The above example is explicit but quite wordy, for this reason in most situations a short hand version of the The above example is explicit but quite wordy. For this reason in most situations a short hand version of the
syntax is preferable. syntax is preferable.
``` ```
@ -446,7 +455,7 @@ Where
* `internal` is an internal variable which the directive exports for binding. * `internal` is an internal variable which the directive exports for binding.
* `key` is an attribute name usually only used to trigger a specific directive. * `key` is an attribute name usually only used to trigger a specific directive.
* `keyExpression` is an property name to which the expression will be bound to. * `keyExpression` is an property name to which the expression will be bound to.
* `varExport` allows exporting of a directive internal state as variable for further binding. If no `internal` name * `varExport` allows exporting of directive internal state as variables for further binding. If no `internal` name
is specified, the exporting is to an implicit variable. is specified, the exporting is to an implicit variable.
* `microsyntax` allows you to build a simple microsyntax which can still clearly identify which expressions bind to * `microsyntax` allows you to build a simple microsyntax which can still clearly identify which expressions bind to
which properties as well as which variables are exported for binding. which properties as well as which variables are exported for binding.
@ -475,12 +484,12 @@ Binding events allows wiring events from DOM (or other components) to the Angula
</table> </table>
Where: Where:
* `some-element` Any element which can generate DOM events (or has angular directive which generates the event). * `some-element` Any element which can generate DOM events (or has an angular directive which generates the event).
* `some-event` (escaped with `()` or `bind-`) is the name of the event `some-event`. In this case the * `some-event` (escaped with `()` or `bind-`) is the name of the event `some-event`. In this case the
dash-case is converted into camel-case `someEvent`. dash-case is converted into camel-case `someEvent`.
* `statement` is a valid statement (as defined in section below). * `statement` is a valid statement (as defined in section below).
By default angular only listens to the element on the event, and ignores events which bubble. To listen to bubbled By default, angular only listens to the element on the event, and ignores events which bubble. To listen to bubbled
events (as in the case of clicking on any child) use the bubble option (`(^event)` or `on-bubble-event`) as shown events (as in the case of clicking on any child) use the bubble option (`(^event)` or `on-bubble-event`) as shown
bellow. bellow.
@ -508,13 +517,13 @@ class Example {
<button (click)="submit()">Submit</button> <button (click)="submit()">Submit</button>
``` ```
In the above example, when clicking on the submit button angular will invoke the `submit` method on the surounding In the above example, when clicking on the submit button angular will invoke the `submit` method on the surrounding
component's controller. component's controller.
NOTE: Unlike Angular v1, Angular v2 treats event bindings as core constructs not as directives. This means that there NOTE: Unlike Angular v1, Angular v2 treats event bindings as core constructs not as directives. This means that there
is no need to create a event directive for each kind of event. This makes it possible for Angular v2 to easily is no need to create a event directive for each kind of event. This makes it possible for Angular v2 to easily
bind to custom events of Custom Elements, whos event names are not known ahead of time. bind to custom events of Custom Elements, whose event names are not known ahead of time.