docs(common): add directives docs

Closes #11581
This commit is contained in:
Victor Berchet 2016-09-12 10:20:33 -07:00 committed by Igor Minar
parent 003294d5df
commit 9cee8bcc83
5 changed files with 143 additions and 192 deletions

View File

@ -11,65 +11,32 @@ import {CollectionChangeRecord, Directive, DoCheck, ElementRef, Input, IterableD
import {isListLikeIterable} from '../facade/collection'; import {isListLikeIterable} from '../facade/collection';
import {isPresent} from '../facade/lang'; import {isPresent} from '../facade/lang';
/** /**
* The `NgClass` directive conditionally adds and removes CSS classes on an HTML element based on * @ngModule CommonModule
* an expression's evaluation result.
* *
* The result of an expression evaluation is interpreted differently depending on type of * @whatItDoes Adds and removes CSS classes on an HTML element.
* the expression evaluation result:
* - `string` - all the CSS classes listed in a string (space delimited) are added
* - `Array` - all the CSS classes (Array elements) are added
* - `Object` - each key corresponds to a CSS class name while values are interpreted as expressions
* evaluating to `Boolean`. If a given expression evaluates to `true` a corresponding CSS class
* is added - otherwise it is removed.
*
* While the `NgClass` directive can interpret expressions evaluating to `string`, `Array`
* or `Object`, the `Object`-based version is the most often used and has an advantage of keeping
* all the CSS class names in a template.
*
* ### Example ([live demo](http://plnkr.co/edit/a4YdtmWywhJ33uqfpPPn?p=preview)):
* *
* @howToUse
* ``` * ```
* import {Component} from '@angular/core'; * <some-element [ngClass]="'first second'">...</some-element>
* import {NgClass} from '@angular/common';
* *
* @Component({ * <some-element [ngClass]="['first', 'second']">...</some-element>
* selector: 'toggle-button',
* inputs: ['isDisabled'],
* template: `
* <div class="button" [ngClass]="{active: isOn, disabled: isDisabled}"
* (click)="toggle(!isOn)">
* Click me!
* </div>`,
* styles: [`
* .button {
* width: 120px;
* border: medium solid black;
* }
* *
* .active { * <some-element [ngClass]="{'first': true, 'second': true, 'third': false}">...</some-element>
* background-color: red;
* }
* *
* .disabled { * <some-element [ngClass]="stringExp|arrayExp|objExp">...</some-element>
* color: gray;
* border: medium solid gray;
* }
* `],
* directives: [NgClass]
* })
* class ToggleButton {
* isOn = false;
* isDisabled = false;
*
* toggle(newState) {
* if (!this.isDisabled) {
* this.isOn = newState;
* }
* }
* }
* ``` * ```
* *
* @description
*
* The CSS classes are updated as follow depending on the type of the expression evaluation:
* - `string` - the CSS classes listed in a string (space delimited) are added,
* - `Array` - the CSS classes (Array elements) are added,
* - `Object` - keys are CSS class names that get added when the expression given in the value
* evaluates to a truthy value, otherwise class are removed.
*
* @stable * @stable
*/ */
@Directive({selector: '[ngClass]'}) @Directive({selector: '[ngClass]'})

View File

@ -14,48 +14,35 @@ import {SwitchView} from './ng_switch';
/** /**
* `ngPlural` is an i18n directive that displays DOM sub-trees that match the switch expression * @ngModule CommonModule
* value, or failing that, DOM sub-trees that match the switch expression's pluralization category. *
* @whatItDoes Adds / removes DOM sub-trees based on a numeric value. Tailored for pluralization.
*
* @howToUse
* ```
* <some-element [ngPlural]="value">
* <ng-container *ngPluralCase="'=0'">there is nothing</ng-container>
* <ng-container *ngPluralCase="'=1'">there is one</ng-container>
* <ng-container *ngPluralCase="'few'">there are a few</ng-container>
* <ng-container *ngPluralCase="'other'">there are exactly #</ng-container>
* </some-element>
* ```
*
* @description
*
* Displays DOM sub-trees that match the switch expression value, or failing that, DOM sub-trees
* that match the switch expression's pluralization category.
* *
* To use this directive you must provide a container element that sets the `[ngPlural]` attribute * To use this directive you must provide a container element that sets the `[ngPlural]` attribute
* to a * to a switch expression. Inner elements with a `[ngPluralCase]` will display based on their
* switch expression. * expression:
* - Inner elements defined with an `[ngPluralCase]` attribute will display based on their * - if `[ngPluralCase]` is set to a value starting with `=`, it will only display if the value
* expression. * matches the switch expression exactly,
* - If `[ngPluralCase]` is set to a value starting with `=`, it will only display if the value * - otherwise, the view will be treated as a "category match", and will only display if exact
* matches the switch expression exactly. * value matches aren't found and the value maps to its category for the defined locale.
* - Otherwise, the view will be treated as a "category match", and will only display if exact
* value matches aren't found and the value maps to its category for the defined locale.
* *
* ```typescript * See http://cldr.unicode.org/index/cldr-spec/plural-rules
* @Component({
* selector: 'app',
* // best practice is to define the locale at the application level
* providers: [{provide: LOCALE_ID, useValue: 'en_US'}]
* })
* @View({
* template: `
* <p>Value = {{value}}</p>
* <button (click)="inc()">Increment</button>
* *
* <div [ngPlural]="value">
* <template ngPluralCase="=0">there is nothing</template>
* <template ngPluralCase="=1">there is one</template>
* <template ngPluralCase="few">there are a few</template>
* <template ngPluralCase="other">there is some number</template>
* </div>
* `,
* directives: [NgPlural, NgPluralCase]
* })
* export class App {
* value = 'init';
*
* inc() {
* this.value = this.value === 'init' ? 0 : this.value + 1;
* }
* }
*
* ```
* @experimental * @experimental
*/ */
@Directive({selector: '[ngPlural]'}) @Directive({selector: '[ngPlural]'})
@ -98,6 +85,19 @@ export class NgPlural {
} }
/** /**
* @ngModule CommonModule
*
* @whatItDoes Creates a view that will be added/removed from the parent {@link NgPlural} when the
* given expression matches the plural expression according to CLDR rules.
*
* @howToUse
* <some-element [ngPlural]="value">
* <ng-container *ngPluralCase="'=0'">...</ng-container>
* <ng-container *ngPluralCase="'other'">...</ng-container>
* </some-element>
*
* See {@link NgPlural} for more details and example.
*
* @experimental * @experimental
*/ */
@Directive({selector: '[ngPluralCase]'}) @Directive({selector: '[ngPluralCase]'})

View File

@ -9,56 +9,24 @@
import {Directive, DoCheck, ElementRef, Input, KeyValueChangeRecord, KeyValueDiffer, KeyValueDiffers, Renderer} from '@angular/core'; import {Directive, DoCheck, ElementRef, Input, KeyValueChangeRecord, KeyValueDiffer, KeyValueDiffers, Renderer} from '@angular/core';
/** /**
* The `NgStyle` directive changes styles based on a result of expression evaluation. * @ngModule CommonModule
* *
* An expression assigned to the `ngStyle` property must evaluate to an object and the * @whatItDoes Update an HTML element styles.
* corresponding element styles are updated based on changes to this object. Style names to update
* are taken from the object's keys, and values - from the corresponding object's values.
*
* ### Syntax
*
* - `<div [ngStyle]="{'font-style': styleExp}"></div>`
* - `<div [ngStyle]="{'max-width.px': widthExp}"></div>`
* - `<div [ngStyle]="styleExp"></div>` - here the `styleExp` must evaluate to an object
*
* ### Example ([live demo](http://plnkr.co/edit/YamGS6GkUh9GqWNQhCyM?p=preview)):
* *
* @howToUse
* ``` * ```
* import {Component} from '@angular/core'; * <some-element [ngStyle]="{'font-style': styleExp}">...</some-element>
* import {NgStyle} from '@angular/common';
* *
* @Component({ * <some-element [ngStyle]="{'max-width.px': widthExp}">...</some-element>
* selector: 'ngStyle-example',
* template: `
* <h1 [ngStyle]="{'font-style': style, 'font-size': size, 'font-weight': weight}">
* Change style of this text!
* </h1>
* *
* <hr> * <some-element [ngStyle]="objExp">...</some-element>
*
* <label>Italic: <input type="checkbox" (change)="changeStyle($event)"></label>
* <label>Bold: <input type="checkbox" (change)="changeWeight($event)"></label>
* <label>Size: <input type="text" [value]="size" (change)="size = $event.target.value"></label>
* `,
* directives: [NgStyle]
* })
* export class NgStyleExample {
* style = 'normal';
* weight = 'normal';
* size = '20px';
*
* changeStyle($event: any) {
* this.style = $event.target.checked ? 'italic' : 'normal';
* }
*
* changeWeight($event: any) {
* this.weight = $event.target.checked ? 'bold' : 'normal';
* }
* }
* ``` * ```
* *
* In this example the `font-style`, `font-size` and `font-weight` styles will be updated * @description
* based on the `style` property's value changes. *
* The styles are updated according to the value of the expression evaluation:
* - keys are style names with an option `.<unit>` suffix (ie 'top.px', 'font-style.em'),
* - values are the values assigned to those properties (expressed in the given unit).
* *
* @stable * @stable
*/ */

View File

@ -22,58 +22,44 @@ export class SwitchView {
} }
/** /**
* Adds or removes DOM sub-trees when their match expressions match the switch expression. * @ngModule CommonModule
* *
* Elements within `NgSwitch` but without `NgSwitchCase` or `NgSwitchDefault` directives will be * @whatItDoes Adds / removes DOM sub-trees when the nest match expressions matches the switch
* preserved at the location as specified in the template. * expression.
* *
* `NgSwitch` simply inserts nested elements based on which match expression matches the value * @howToUse
* obtained from the evaluated switch expression. In other words, you define a container element
* (where you place the directive with a switch expression on the
* `[ngSwitch]="..."` attribute), define any inner elements inside of the directive and
* place a `[ngSwitchCase]` attribute per element.
*
* The `ngSwitchCase` property is used to inform `NgSwitch` which element to display when the
* expression is evaluated. If a matching expression is not found via a `ngSwitchCase` property
* then an element with the `ngSwitchDefault` attribute is displayed.
*
* ### Example ([live demo](http://plnkr.co/edit/DQMTII95CbuqWrl3lYAs?p=preview))
*
* ```typescript
* @Component({
* selector: 'app',
* template: `
* <p>Value = {{value}}</p>
* <button (click)="inc()">Increment</button>
*
* <div [ngSwitch]="value">
* <p *ngSwitchCase="'init'">increment to start</p>
* <p *ngSwitchCase="0">0, increment again</p>
* <p *ngSwitchCase="1">1, increment again</p>
* <p *ngSwitchCase="2">2, stop incrementing</p>
* <p *ngSwitchDefault>&gt; 2, STOP!</p>
* </div>
*
* <!-- alternate syntax -->
*
* <p [ngSwitch]="value">
* <template ngSwitchCase="init">increment to start</template>
* <template [ngSwitchCase]="0">0, increment again</template>
* <template [ngSwitchCase]="1">1, increment again</template>
* <template [ngSwitchCase]="2">2, stop incrementing</template>
* <template ngSwitchDefault>&gt; 2, STOP!</template>
* </p>
* `,
* directives: [NgSwitch, NgSwitchCase, NgSwitchDefault]
* })
* export class App {
* value = 'init';
*
* inc() {
* this.value = this.value === 'init' ? 0 : this.value + 1;
* }
* }
* ``` * ```
* <container-element [ngSwitch]="switch_expression">
* <some-element *ngSwitchCase="match_expression_1">...</some-element>
* <some-element *ngSwitchCase="match_expression_2">...</some-element>
* <some-other-element *ngSwitchCase="match_expression_3">...</some-other-element>
* <ng-container *ngSwitchCase="match_expression_3">
* <!-- use a ng-container to group multiple root nodes -->
* <inner-element></inner-element>
* <inner-other-element></inner-other-element>
* </ng-container>
* <some-element *ngSwitchDefault>...</p>
* </container-element>
* ```
* @description
*
* `NgSwitch` stamps out nested views when their match expression value matches the value of the
* switch expression.
*
* In other words:
* - you define a container element (where you place the directive with a switch expression on the
* `[ngSwitch]="..."` attribute)
* - you define inner views inside the `NgSwitch` and place a `*ngSwitchCase` attribute on the view
* root elements.
*
* Elements within `NgSwitch` but outside of a `NgSwitchCase` or `NgSwitchDefault` directives will
* be
* preserved at the location.
*
* The `ngSwitchCase` directive informs the parent `NgSwitch` of which view to display when the
* expression is evaluated.
* When no matching expression is found on a `ngSwitchCase` view, the `ngSwitchDefault` view is
* stamped out.
* *
* @stable * @stable
*/ */
@ -169,10 +155,23 @@ export class NgSwitch {
} }
/** /**
* Insert the sub-tree when the `ngSwitchCase` expression evaluates to the same value as the * @ngModule CommonModule
* enclosing switch expression.
* *
* If multiple match expression match the switch expression value, all of them are displayed. * @whatItDoes Creates a view that will be added/removed from the parent {@link NgSwitch} when the
* given expression evaluate to respectively the same/different value as the switch
* expression.
*
* @howToUse
* <container-element [ngSwitch]="switch_expression">
* <some-element *ngSwitchCase="match_expression_1">...</some-element>
* </container-element>
*
* @description
*
* Insert the sub-tree when the expression evaluates to the same value as the enclosing switch
* expression.
*
* If multiple match expressions match the switch expression value, all of them are displayed.
* *
* See {@link NgSwitch} for more details and example. * See {@link NgSwitch} for more details and example.
* *
@ -202,8 +201,21 @@ export class NgSwitchCase {
} }
/** /**
* Default case statements are displayed when no match expression matches the switch expression * @ngModule CommonModule
* value. * @whatItDoes Creates a view that is added to the parent {@link NgSwitch} when no case expressions
* match the
* switch expression.
*
* @howToUse
* <container-element [ngSwitch]="switch_expression">
* <some-element *ngSwitchCase="match_expression_1">...</some-element>
* <some-other-element *ngSwitchDefault>...</some-other-element>
* </container-element>
*
* @description
*
* Insert the sub-tree when no case expressions evaluate to the same value as the enclosing switch
* expression.
* *
* See {@link NgSwitch} for more details and example. * See {@link NgSwitch} for more details and example.
* *

View File

@ -9,21 +9,25 @@
import {Directive, EmbeddedViewRef, Input, OnChanges, TemplateRef, ViewContainerRef} from '@angular/core'; import {Directive, EmbeddedViewRef, Input, OnChanges, TemplateRef, ViewContainerRef} from '@angular/core';
/** /**
* Creates and inserts an embedded view based on a prepared `TemplateRef`. * @ngModule CommonModule
* You can attach a context object to the `EmbeddedViewRef` by setting `[ngOutletContext]`.
* `[ngOutletContext]` should be an object, the object's keys will be the local template variables
* available within the `TemplateRef`.
* *
* Note: using the key `$implicit` in the context object will set it's value as default. * @whatItDoes Inserts an embedded view from a prepared `TemplateRef`
*
* ### Syntax
* *
* @howToUse
* ``` * ```
* <template [ngTemplateOutlet]="templateRefExpression" * <template [ngTemplateOutlet]="templateRefExpression"
* [ngOutletContext]="objectExpression"> * [ngOutletContext]="objectExpression">
* </template> * </template>
* ``` * ```
* *
* @description
*
* You can attach a context object to the `EmbeddedViewRef` by setting `[ngOutletContext]`.
* `[ngOutletContext]` should be an object, the object's keys will be the local template variables
* available within the `TemplateRef`.
*
* Note: using the key `$implicit` in the context object will set it's value as default.
*
* @experimental * @experimental
*/ */
@Directive({selector: '[ngTemplateOutlet]'}) @Directive({selector: '[ngTemplateOutlet]'})