Merge remote-tracking branch 'origin/master'

# Conflicts:
#	public/docs/ts/latest/guide/animations.jade
#	public/docs/ts/latest/guide/npm-packages.jade
#	public/docs/ts/latest/guide/router.jade
#	public/docs/ts/latest/guide/upgrade.jade
This commit is contained in:
Zhicheng Wang 2016-07-26 17:45:25 +08:00
commit 7916ec4c8d
8 changed files with 96 additions and 42 deletions

View File

@ -1,7 +1,7 @@
// #docregion // #docregion
export const heroDetail = { export const heroDetail = {
bindings: { bindings: {
hero: '=', hero: '<',
deleted: '&' deleted: '&'
}, },
template: ` template: `

View File

@ -662,11 +662,20 @@ block injectable-not-always-needed-in-ts
block ts-any-decorator-will-do block ts-any-decorator-will-do
.l-sub-section .l-sub-section
:marked :marked
Injectors use a class's constructor metadata to determine dependent types as At runtime, injectors can read class metadata in the transpiled JavaScript code
identified by the constructor's parameter types. and use the constructor parameter type information
TypeScript generates such metadata for any class with a decorator, and any decorator will do. to determine what things to inject.
But of course, it is more meaningful to mark a class using the appropriate
<a href="#{injMetaUrl}">InjectableMetadata</a> #{_decorator}. Not every JavaScript class has metadata.
The TypeScript compiler discards metadata by default.
If the `emitDecoratorMetadata` compiler option is true
(as it should be in the `tsconfig.json`),
the compiler adds the metadata to the generated JavaScript
for _every class with at least one decorator_.
While any decorator will trigger this effect, mark the service class with the
<a href="#{injMetaUrl}">InjectableMetadata</a> #{_decorator}
to make the intent clear.
注入器使用一个类的构造元数据来决定依赖类型,该构造元数据就是构造函数的参数类型所标识的。 注入器使用一个类的构造元数据来决定依赖类型,该构造元数据就是构造函数的参数类型所标识的。
TypeScript为任何带有一个装饰器的类生成这样的元数据任何装饰器都生成。 TypeScript为任何带有一个装饰器的类生成这样的元数据任何装饰器都生成。

View File

@ -13,7 +13,7 @@ include ../_util-fns
Node.js和npm是做Angular 2开发的基础。 Node.js和npm是做Angular 2开发的基础。
<a href="https://docs.npmjs.com/getting-started/installing-node" target="_blank" title="Installing Node.js and updating npm"> <a href="https://docs.npmjs.com/getting-started/installing-node" target="_blank" title="Installing Node.js and updating npm">
Get it now</a> if it's not already installed on your machine Get it now</a> if it's not already installed on your machine.
如果你的电脑上还没有装过,请<a href="https://docs.npmjs.com/getting-started/installing-node" target="_blank" title="Installing Node.js and updating npm">立即获取它</a> 如果你的电脑上还没有装过,请<a href="https://docs.npmjs.com/getting-started/installing-node" target="_blank" title="Installing Node.js and updating npm">立即获取它</a>
@ -131,13 +131,13 @@ a(id="dependencies")
这个包还包含bootstrapStatic方法用来引导那些在产品构建时需要离线预编译模板的应用程序。 这个包还包含bootstrapStatic方法用来引导那些在产品构建时需要离线预编译模板的应用程序。
***@angular/platform-browser-dynamic*** - Providers and a bootstrap method for applications that ***@angular/platform-browser-dynamic*** - Providers and a bootstrap method for applications that
compile templates on the client. dont use offline compilation. compile templates on the client. Dont use offline compilation.
We use this package for boostrapping during development and for boostrapping plunker samples We use this package for boostrapping during development and for boostrapping plunker samples.
***@angular/platform-browser-dynamic*** - 为应用程序提供一些提供商和一个bootstrap方法以便在客户端编译模板。不要用于离线编译。 ***@angular/platform-browser-dynamic*** - 为应用程序提供一些提供商和一个bootstrap方法以便在客户端编译模板。不要用于离线编译。
我们使用这个包在开发期间引导应用以及引导plunker中的范例。 我们使用这个包在开发期间引导应用以及引导plunker中的范例。
***@angular/http*** - Angular's http client ***@angular/http*** - Angular's http client.
***@angular/http*** - Angular的HTTP客户端。 ***@angular/http*** - Angular的HTTP客户端。
@ -187,7 +187,7 @@ a(id="polyfills")
查看下面的“[为什么用peerDependencies?](#why-peer-dependencies)”,以了解这项需求的背景。 查看下面的“[为什么用peerDependencies?](#why-peer-dependencies)”,以了解这项需求的背景。
:marked :marked
***core-js*** - monkey patches the global context (window) with essential features of ES2015 (ES6). ***core-js*** - Monkey patches the global context (window) with essential features of ES2015 (ES6).
Developers may substitute an alternative polyfill that provides the same core APIs. Developers may substitute an alternative polyfill that provides the same core APIs.
This dependency should go away once these APIs are implemented by all supported ever-green browsers. This dependency should go away once these APIs are implemented by all supported ever-green browsers.
@ -195,14 +195,14 @@ a(id="polyfills")
开发人员也可以把它换成提供了相同内核API的其它填充库。 开发人员也可以把它换成提供了相同内核API的其它填充库。
如果有一天所有“长青浏览器”都实现了这些API这个依赖就可以去掉了。 如果有一天所有“长青浏览器”都实现了这些API这个依赖就可以去掉了。
***reflect-metadata*** - a dependency shared between Angular and the ***TypeScript compiler***. ***reflect-metadata*** - A dependency shared between Angular and the ***TypeScript compiler***.
Developers should be able to update a TypeScript package without upgrading Angular, Developers should be able to update a TypeScript package without upgrading Angular,
which is why this is a dependency of the application and not a dependency of Angular. which is why this is a dependency of the application and not a dependency of Angular.
***reflect-metadata*** - 一个由Angular和***TypeScript***编译器共享的依赖包。 ***reflect-metadata*** - 一个由Angular和***TypeScript***编译器共享的依赖包。
开发人员需要能单独更新TypeScript包而不用升级Angular。这就是为什么把它放在本应用程序的依赖中而不是Angular的依赖中。 开发人员需要能单独更新TypeScript包而不用升级Angular。这就是为什么把它放在本应用程序的依赖中而不是Angular的依赖中。
***rxjs*** - a polyfill for the [Observables specification](https://github.com/zenparsing/es-observable) currently before the ***rxjs*** - A polyfill for the [Observables specification](https://github.com/zenparsing/es-observable) currently before the
[TC39](http://www.ecma-international.org/memento/TC39.htm) committee that determines standards for the JavaScript language. [TC39](http://www.ecma-international.org/memento/TC39.htm) committee that determines standards for the JavaScript language.
Developers should be able to pick a preferred version of *rxjs* (within a compatible version range) Developers should be able to pick a preferred version of *rxjs* (within a compatible version range)
without waiting for Angular updates. without waiting for Angular updates.
@ -211,7 +211,7 @@ a(id="polyfills")
[TC39](http://www.ecma-international.org/memento/TC39.htm)委员会以决定是否要在JavaScript语言中进行标准化。 [TC39](http://www.ecma-international.org/memento/TC39.htm)委员会以决定是否要在JavaScript语言中进行标准化。
开发人员应该能在兼容的版本中选择一个喜欢的*rxjs*版本而不用等Angular升级。 开发人员应该能在兼容的版本中选择一个喜欢的*rxjs*版本而不用等Angular升级。
***zone.js*** - a polyfill for the [Zone specification](https://gist.github.com/mhevery/63fdcdf7c65886051d55) currently before the ***zone.js*** - A polyfill for the [Zone specification](https://gist.github.com/mhevery/63fdcdf7c65886051d55) currently before the
[TC39](http://www.ecma-international.org/memento/TC39.htm) committee that determines standards for the JavaScript language. [TC39](http://www.ecma-international.org/memento/TC39.htm) committee that determines standards for the JavaScript language.
Developers should be able to pick a preferred version of *zone.js* to use (within a compatible version range) Developers should be able to pick a preferred version of *zone.js* to use (within a compatible version range)
without waiting for Angular updates. without waiting for Angular updates.
@ -235,7 +235,7 @@ a(id="other")
对演示、文档范例和开发的早期阶段(那时候我们可能还没有服务器呢)非常有用。 对演示、文档范例和开发的早期阶段(那时候我们可能还没有服务器呢)非常有用。
请到[Http客户端](server-communication.html#appendix-tour-of-heroes-in-memory-server)一章中了解更多知识。 请到[Http客户端](server-communication.html#appendix-tour-of-heroes-in-memory-server)一章中了解更多知识。
***bootstrap*** - [bootstrap](http://getbootstrap.com/) is a popular HTML and CSS framework for designing responsive web apps. ***bootstrap*** - [Bootstrap](http://getbootstrap.com/) is a popular HTML and CSS framework for designing responsive web apps.
Some of the documentation samples improve their appearance with *bootstrap*. Some of the documentation samples improve their appearance with *bootstrap*.
***bootstrap*** - [bootstrap](http://getbootstrap.com/)是一个广受欢迎的HTML和CSS框架可用来设计响应式网络应用。 ***bootstrap*** - [bootstrap](http://getbootstrap.com/)是一个广受欢迎的HTML和CSS框架可用来设计响应式网络应用。
@ -252,23 +252,23 @@ a(id="dev-dependencies")
它们不用部署到产品环境的应用程序中 —— 虽然这样做也没什么坏处。 它们不用部署到产品环境的应用程序中 —— 虽然这样做也没什么坏处。
***[concurrently](https://www.npmjs.com/package/concurrently)*** - ***[concurrently](https://www.npmjs.com/package/concurrently)*** -
a utility to run multiple *npm* commands concurrently on OS/X, Windows, and Linux operating systems. A utility to run multiple *npm* commands concurrently on OS/X, Windows, and Linux operating systems.
***[concurrently](https://www.npmjs.com/package/concurrently)*** - 一个用来在OS/X、Windows和Linux操作系统上同时运行多个*npm*命令的工具 ***[concurrently](https://www.npmjs.com/package/concurrently)*** - 一个用来在OS/X、Windows和Linux操作系统上同时运行多个*npm*命令的工具
***[lite-server](https://www.npmjs.com/package/lite-server)*** - ***[lite-server](https://www.npmjs.com/package/lite-server)*** -
a light-weight, static file server, written and maintained by [John Papa](http://johnpapa.net/) A light-weight, static file server, written and maintained by [John Papa](http://johnpapa.net/)
with excellent support for Angular apps that use routing. with excellent support for Angular apps that use routing.
***[lite-server](https://www.npmjs.com/package/lite-server)*** - 一个轻量级、静态的服务器, ***[lite-server](https://www.npmjs.com/package/lite-server)*** - 一个轻量级、静态的服务器,
由[John Papa](http://johnpapa.net/)开发和维护。对使用到路由的Angular程序提供了很好的支持。 由[John Papa](http://johnpapa.net/)开发和维护。对使用到路由的Angular程序提供了很好的支持。
***[typescript](https://www.npmjs.com/package/typescript)*** - ***[typescript](https://www.npmjs.com/package/typescript)*** -
the TypeScript language server including the *tsc* TypeScript compiler. The TypeScript language server including the *tsc* TypeScript compiler.
***[typescript](https://www.npmjs.com/package/typescript)*** - TypeScript语言的服务器包含了TypeScript编译器*tsc*。 ***[typescript](https://www.npmjs.com/package/typescript)*** - TypeScript语言的服务器包含了TypeScript编译器*tsc*。
***[typings](https://www.npmjs.com/package/typings)*** - a manager for TypeScript definition files. ***[typings](https://www.npmjs.com/package/typings)*** - A manager for TypeScript definition files.
Learn more about it in the [TypeScript Configuration](typescript-configuration.html#typings) chapter. Learn more about it in the [TypeScript Configuration](typescript-configuration.html#typings) chapter.
***[typings](https://www.npmjs.com/package/typings)*** - 一个“TypeScript定义”文件管理器。 ***[typings](https://www.npmjs.com/package/typings)*** - 一个“TypeScript定义”文件管理器。

View File

@ -472,7 +472,7 @@ table
td td
p. p.
The current state of the router including a tree of the currently activated The current state of the router including a tree of the currently activated
activated routes in our application along with the URL query params, fragment routes in our application along with the URL query params, fragment
and convenience methods for traversing the route tree. and convenience methods for traversing the route tree.
p. p.
路由器的当前状态包含了一棵由程序中激活的路由构成的树。它包含URL查询参数、片段和用于遍历路由树的快捷方法。 路由器的当前状态包含了一棵由程序中激活的路由构成的树。它包含URL查询参数、片段和用于遍历路由树的快捷方法。

View File

@ -931,6 +931,17 @@ table
:marked :marked
`<my-component (myOutput)="action()">` `<my-component (myOutput)="action()">`
tr tr
th
p One-way binding
p 单向绑定
td
:marked
`myValue: '<myValue'`
td
:marked
`<my-component [myValue]="anExpression">`
tr
th Two-way binding
th th
p Two-way binding p Two-way binding
p 双向绑定 p 双向绑定
@ -939,8 +950,9 @@ table
`myValue: '=myValue'` `myValue: '=myValue'`
td td
:marked :marked
As input: `<my-component [myValue]="anExpression">` or As a two-way binding: `<my-component [(myValue)]="anExpression">`.
as two-way binding: `<my-component [(myValue)]="anExpression"` Since most Angular 1 two-way bindings actually only need a one-way binding
in practice, `<my-component [myValue]="anExpression">` is often enough.
用作输入:`<my-component [myValue]="anExpression">` 或 用作输入:`<my-component [myValue]="anExpression">` 或
用作双向绑定:`<my-component [(myValue)]="anExpression"` 用作双向绑定:`<my-component [(myValue)]="anExpression"`

Binary file not shown.

Before

Width:  |  Height:  |  Size: 206 KiB

After

Width:  |  Height:  |  Size: 210 KiB

File diff suppressed because one or more lines are too long

Before

Width:  |  Height:  |  Size: 254 KiB

After

Width:  |  Height:  |  Size: 257 KiB

View File

@ -224,8 +224,7 @@ function encodeBase64(file) {
} }
function createPlunkerHtml(postData) { function createPlunkerHtml(postData) {
useNewWindow = false; var baseHtml = createBasePlunkerHtml(false);
var baseHtml = createBasePlunkerHtml(useNewWindow);
var doc = jsdom.jsdom(baseHtml); var doc = jsdom.jsdom(baseHtml);
var form = doc.querySelector('form'); var form = doc.querySelector('form');
_.forEach(postData, function(value, key) { _.forEach(postData, function(value, key) {