翻译完了toh-pt4的新增内容

This commit is contained in:
Zhicheng Wang 2017-04-16 22:04:21 +08:00
parent e5c750301c
commit e4df9a8634
1 changed files with 29 additions and 4 deletions

View File

@ -2,15 +2,22 @@ include ../_util-fns
:marked :marked
As the Tour of Heroes app evolves, you'll add more components that need access to hero data. As the Tour of Heroes app evolves, you'll add more components that need access to hero data.
随着《英雄指南》的成长,我们要添加更多需要访问英雄数据的组件。
Instead of copying and pasting the same code over and over, Instead of copying and pasting the same code over and over,
you'll create a single reusable data service and you'll create a single reusable data service and
inject it into the components that need it. inject it into the components that need it.
Using a separate service keeps components lean and focused on supporting the view, Using a separate service keeps components lean and focused on supporting the view,
and makes it easy to unit-test components with a mock service. and makes it easy to unit-test components with a mock service.
为了不再把相同的代码复制一遍又一遍,我们要创建一个单一的可复用的数据服务,并且把它注入到需要它的那些组件中。
使用单独的服务可以保持组件精简使其集中精力为视图提供支持并且借助模拟Mock服务可以更容易的对组件进行单元测试。
Because data services are invariably asynchronous, Because data services are invariably asynchronous,
you'll finish the page with a *Promise*-based version of the data service. you'll finish the page with a *Promise*-based version of the data service.
由于数据服务总是异步的因此我们最终会提供一个基于承诺Promise的数据服务。
When you're done with this page, the app should look like this <live-example></live-example>. When you're done with this page, the app should look like this <live-example></live-example>.
@ -94,7 +101,13 @@ code-example(language="sh" class="code-shell").
在这一章,我们将把获取英雄数据的任务重构为一个单独的服务,它将提供英雄数据,并把服务在所有需要英雄数据的组件间共享。 在这一章,我们将把获取英雄数据的任务重构为一个单独的服务,它将提供英雄数据,并把服务在所有需要英雄数据的组件间共享。
### Create the HeroService ### Create the HeroService
### 创建 HeroService Create a file in the `app` folder called `hero.service.ts`. 在`app`目录下创建一个名叫`hero.service.ts`的文件。
### 创建 HeroService
Create a file in the `app` folder called `hero.service.ts`.
在`app`目录下创建一个名叫`hero.service.ts`的文件。
.l-sub-section .l-sub-section
:marked :marked
The naming convention for service files is the service name in lowercase followed by `.service`. The naming convention for service files is the service name in lowercase followed by `.service`.
@ -104,6 +117,7 @@ code-example(language="sh" class="code-shell").
我们遵循的文件命名约定是:服务名称的小写形式(基本名),加上`.service`后缀。 我们遵循的文件命名约定是:服务名称的小写形式(基本名),加上`.service`后缀。
如果服务名称包含多个单词,我们就把基本名部分写成中线形式 ([dash-case](../guide/glossary.html#dash-case))。 如果服务名称包含多个单词,我们就把基本名部分写成中线形式 ([dash-case](../guide/glossary.html#dash-case))。
例如,`SpecialSuperHeroService`服务应该被定义在`special-super-hero.service.ts`文件中。 例如,`SpecialSuperHeroService`服务应该被定义在`special-super-hero.service.ts`文件中。
:marked :marked
Name the class `HeroService` and export it for others to import. Name the class `HeroService` and export it for others to import.
@ -119,11 +133,13 @@ code-example(language="sh" class="code-shell").
Notice that you imported the Angular `Injectable` function and applied that function as an `@Injectable()` decorator. Notice that you imported the Angular `Injectable` function and applied that function as an `@Injectable()` decorator.
注意,我们导入了 Angular 的`Injectable`函数,并作为`@Injectable()`装饰器使用这个函数。 注意,我们导入了 Angular 的`Injectable`函数,并作为`@Injectable()`装饰器使用这个函数。
.callout.is-helpful .callout.is-helpful
:marked :marked
Don't forget the parentheses. Omitting them leads to an error that's difficult to diagnose. Don't forget the parentheses. Omitting them leads to an error that's difficult to diagnose.
**不要忘了写圆括号!**如果忘了写,就会导致一个很难诊断的错误。 **不要忘了写圆括号!**如果忘了写,就会导致一个很难诊断的错误。
:marked :marked
The `@Injectable()` decorator tells TypeScript to emit metadata about the service. The `@Injectable()` decorator tells TypeScript to emit metadata about the service.
The metadata specifies that Angular may need to inject other dependencies into this service. The metadata specifies that Angular may need to inject other dependencies into this service.
@ -172,6 +188,7 @@ code-example(language="sh" class="code-shell").
还要复制`import {Hero}...`语句,因为我们的英雄数组用到了`Hero`类。 还要复制`import {Hero}...`语句,因为我们的英雄数组用到了`Hero`类。
+makeExample('toh-4/ts/src/app/mock-heroes.ts', null, 'src/app/mock-heroes.ts') +makeExample('toh-4/ts/src/app/mock-heroes.ts', null, 'src/app/mock-heroes.ts')
:marked :marked
The `HEROES` constant is exported so it can be imported elsewhere, such as the `HeroService`. The `HEROES` constant is exported so it can be imported elsewhere, such as the `HeroService`.
@ -183,6 +200,7 @@ code-example(language="sh" class="code-shell").
在刚刚剪切出`HEROES`数组的`app.component.ts`文件中,添加一个尚未初始化的`heroes`属性: 在刚刚剪切出`HEROES`数组的`app.component.ts`文件中,添加一个尚未初始化的`heroes`属性:
+makeExample('toh-4/ts/src/app/app.component.1.ts', 'heroes-prop', 'src/app/app.component.ts (heroes property)')(format=".") +makeExample('toh-4/ts/src/app/app.component.1.ts', 'heroes-prop', 'src/app/app.component.ts (heroes property)')(format=".")
:marked :marked
### Return mocked hero data ### Return mocked hero data
@ -277,6 +295,7 @@ code-example(language="sh" class="code-shell").
添加构造函数: 添加构造函数:
+makeExample('toh-4/ts/src/app/app.component.1.ts', 'ctor', 'src/app/app.component.ts (constructor)') +makeExample('toh-4/ts/src/app/app.component.1.ts', 'ctor', 'src/app/app.component.ts (constructor)')
:marked :marked
The constructor itself does nothing. The parameter simultaneously The constructor itself does nothing. The parameter simultaneously
defines a private `heroService` property and identifies it as a `HeroService` injection site. defines a private `heroService` property and identifies it as a `HeroService` injection site.
@ -293,6 +312,7 @@ code-example(language="sh" class="code-shell").
Read more about dependency injection in the [Dependency Injection](../guide/dependency-injection.html) page. Read more about dependency injection in the [Dependency Injection](../guide/dependency-injection.html) page.
更多依赖注入的信息,见[依赖注入](../guide/dependency-injection.html)。 更多依赖注入的信息,见[依赖注入](../guide/dependency-injection.html)。
:marked :marked
The *injector* doesn't know yet how to create a `HeroService`. The *injector* doesn't know yet how to create a `HeroService`.
If you ran the code now, Angular would fail with this error: If you ran the code now, Angular would fail with this error:
@ -343,7 +363,9 @@ a#child-component
在真实的世界中,我们并不需要把一行代码包装成一个专门的方法,但无论如何,我们在演示代码中先这么写: 在真实的世界中,我们并不需要把一行代码包装成一个专门的方法,但无论如何,我们在演示代码中先这么写:
+makeExcerpt('toh-4/ts/src/app/app.component.1.ts', 'getHeroes', 'src/app/app.component.ts') +makeExcerpt('toh-4/ts/src/app/app.component.1.ts', 'getHeroes', 'src/app/app.component.ts')
<a id="oninit"></a> <a id="oninit"></a>
:marked :marked
### The *ngOnInit* lifecycle hook ### The *ngOnInit* lifecycle hook
@ -460,6 +482,7 @@ code-example(format="nocode").
把`HeroService`的`getHeroes`方法改写为返回承诺的形式: 把`HeroService`的`getHeroes`方法改写为返回承诺的形式:
+makeExample('toh-4/ts/src/app/hero.service.ts', 'get-heroes', 'src/app/hero.service.ts (excerpt)')(format=".") +makeExample('toh-4/ts/src/app/hero.service.ts', 'get-heroes', 'src/app/hero.service.ts (excerpt)')(format=".")
:marked :marked
You're still mocking the data. You're simulating the behavior of an ultra-fast, zero-latency server, You're still mocking the data. You're simulating the behavior of an ultra-fast, zero-latency server,
by returning an *immediately resolved Promise* with the mock heroes as the result. by returning an *immediately resolved Promise* with the mock heroes as the result.
@ -496,6 +519,7 @@ code-example(format="nocode").
回调中所用的 [ES2015 箭头函数](https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Functions/Arrow_functions) 回调中所用的 [ES2015 箭头函数](https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Functions/Arrow_functions)
比等价的函数表达式更加简洁,能优雅的处理 *this* 指针。 比等价的函数表达式更加简洁,能优雅的处理 *this* 指针。
:marked :marked
The callback sets the component's `heroes` property to the array of heroes returned by the service. The callback sets the component's `heroes` property to the array of heroes returned by the service.
@ -510,7 +534,8 @@ code-example(format="nocode").
:marked :marked
At the end of this page, [Appendix: take it slow](#slow) describes what the app might be like with a poor connection. At the end of this page, [Appendix: take it slow](#slow) describes what the app might be like with a poor connection.
查看附录中的“[慢一点](#slow)”,来了解在较差的网络连接中这个应用会是什么样的。 查看附录中的“[慢!](#slow)”,来了解在较差的网络连接中这个应用会是什么样的。
:marked :marked
## Review the app structure ## Review the app structure
@ -581,7 +606,7 @@ code-example(format="nocode").
* You designed the service to return a Promise and the component to get the data from the Promise. * You designed the service to return a Promise and the component to get the data from the Promise.
我们把服务设计为返回承诺,组件从承诺中获取数据。 我们把服务设计为返回承诺,组件从承诺中获取数据。
Your app should look like this <live-example></live-example>. Your app should look like this <live-example></live-example>.
@ -608,7 +633,7 @@ code-example(format="nocode").
:marked :marked
## Appendix: Take it slow ## Appendix: Take it slow
## 附件:慢一点 ## 附件:慢
To simulate a slow connection, To simulate a slow connection,
import the `Hero` symbol and add the following `getHeroesSlowly()` method to the `HeroService`. import the `Hero` symbol and add the following `getHeroesSlowly()` method to the `HeroService`.