router.jade review to line 1586

This commit is contained in:
Rex 2016-06-29 19:43:59 +01:00
parent 77fc29977b
commit 397a1247b8
1 changed files with 32 additions and 31 deletions

View File

@ -918,7 +918,7 @@ h3#router-directives <i>ROUTER_DIRECTIVES</i>(路由指令集)
Remember to add them to the `directives` array of the `@Component` metadata. Remember to add them to the `directives` array of the `@Component` metadata.
`RouterLink`和`RouterOutlet`是`ROUTER_DIRECTIVES`集合中的指令。 `RouterLink`和`RouterOutlet`是`ROUTER_DIRECTIVES`集合中的指令。
记住把它们加入`@Component`元数据的`directives`数组中。 记住把它们加入`@Component`元数据的`directives`数组中。
+makeExample('router/ts/app/app.component.1.ts','directives')(format=".") +makeExample('router/ts/app/app.component.1.ts','directives')(format=".")
@ -966,12 +966,12 @@ h3#router-directives <i>ROUTER_DIRECTIVES</i>(路由指令集)
The rest of the starter app is mundane, with little interest from a router perspective. The rest of the starter app is mundane, with little interest from a router perspective.
Here are the details for readers inclined to build the sample through to this milestone. Here are the details for readers inclined to build the sample through to this milestone.
这个初学者应用平淡无奇,唯独路由器方面还稍微有趣点 这个初学者应用的其他部分有点平淡无奇,从路由器的角度来看也很平淡
如果你还是倾向于在这个里程碑里构建它们,参见下面的构建详情。
Our starter app's structure looks like this: Our starter app's structure looks like this:
我们这个初学者应用的结构看起来是这样的: 这个初学者应用的结构看起来是这样的:
.filetree .filetree
.file router-sample .file router-sample
@ -1020,7 +1020,7 @@ h2#heroes-feature 里程碑#2: “英雄”特性区
:marked :marked
We've seen how to navigate using the `RouterLink` directive. We've seen how to navigate using the `RouterLink` directive.
我们已经看到了如何用`RouterLink`指令进行导航。 我们刚刚学习了如何用`RouterLink`指令进行导航。
Now we'll learn some new tricks such as how to Now we'll learn some new tricks such as how to
@ -1032,7 +1032,7 @@ h2#heroes-feature 里程碑#2: “英雄”特性区
* navigate imperatively from one component to another * navigate imperatively from one component to another
* 强制从一个组件导航到另一个组件 * 命令式地从一个组件导航到另一个组件
* pass information in route parameters * pass information in route parameters
@ -1055,19 +1055,19 @@ h2#heroes-feature 里程碑#2: “英雄”特性区
That's unrealistic and ultimately not maintainable. That's unrealistic and ultimately not maintainable.
We think it's better to put each feature area in its own folder. We think it's better to put each feature area in its own folder.
当然,我们可以继续把文件全添加到`app/`目录中。 我们可以继续把文件全添加到`app/`目录中。
但那么做不太现实,并且最终将无法维护。 但那么做不太现实,并且最终将无法维护。
因此,我们认为把每个特性区都放进自己的目录中会更好一些。 因此,把每个特性区都放进自己的目录中会更好一些。
Our first step is to **create a separate `app/heroes/` folder** Our first step is to **create a separate `app/heroes/` folder**
and add *Hero Management* feature files there. and add *Hero Management* feature files there.
我们的第一步是**创建一个独立的`app/heroes/`文件夹**,并在其中添加属于*英雄管理*特性区的那些文件。 第一步是**创建一个独立的`app/heroes/`文件夹**,并在其中添加属于*英雄管理*特性区的文件。
We won't be creative about it. Our example is pretty much a We won't be creative about it. Our example is pretty much a
copy of the code and capabilities in the "[Tutorial: Tour of Heroes](../tutorial/index.html)". copy of the code and capabilities in the "[Tutorial: Tour of Heroes](../tutorial/index.html)".
我们不会在这里创新。这个例子从代码上和功能上来看几乎就是“[教程: 英雄指南](../tutorial/index.html)”的一份拷贝。 我们没有在这里引进新东西。这个例子从代码上和功能上来看,几乎就是“[教程: 英雄指南](../tutorial/index.html)”的一份拷贝。
Here's how the user will experience this version of the app Here's how the user will experience this version of the app
@ -1091,7 +1091,7 @@ figure.image-display
We copy the `hero-detail.component.ts` and the `hero.service.ts` files We copy the `hero-detail.component.ts` and the `hero.service.ts` files
into the `heroes/` folder. into the `heroes/` folder.
然后在`app/heroes/`目录下创建了一个`hero-list.component.ts`文件,并从教程中把`heroes.component.ts`最终版的内容拷贝进来。 然后在`app/heroes/`目录下创建了一个`hero-list.component.ts`文件,并从上面的教程中把`heroes.component.ts`最终版的内容拷贝进来。
再把`hero-detail.component.ts`和`hero.service.ts`文件拷贝到`heroes/`目录下。 再把`hero-detail.component.ts`和`hero.service.ts`文件拷贝到`heroes/`目录下。
When we're done organizing, we have three *Hero Management* files: When we're done organizing, we have three *Hero Management* files:
@ -1114,7 +1114,7 @@ figure.image-display
Now it's time for some surgery to bring these files and the rest of the app Now it's time for some surgery to bring these files and the rest of the app
into alignment with our application router. into alignment with our application router.
现在,该通过一些“外科手术”来让这些文件和应用的其它部分向本应用的路由器看齐了 现在到时间做一些“外科手术”了。我们利用应用程序的路由器,把这些文件和应用的其它部分联合起来
### *Hero* feature routing requirements ### *Hero* feature routing requirements
@ -1130,7 +1130,7 @@ figure.image-display
The detail view is different. It displays a particular hero. It can't know which hero on its own. The detail view is different. It displays a particular hero. It can't know which hero on its own.
That information must come from outside. That information must come from outside.
详情视图就不同了。它要显示一个特定的英雄,但是它本身却法知道显示哪一个,此信息必须来自外部。 详情视图就不同了。它要显示一个特定的英雄,但是它本身却法知道显示哪一个,此信息必须来自外部。
In our example, when the user selects a hero from the list, we navigate to the detail view to show that hero. In our example, when the user selects a hero from the list, we navigate to the detail view to show that hero.
We'll tell the detail view which hero to display by including the selected hero's id in the route URL. We'll tell the detail view which hero to display by including the selected hero's id in the route URL.
@ -1144,7 +1144,7 @@ figure.image-display
We recommend giving each feature area its own route configuration file. We recommend giving each feature area its own route configuration file.
我们推荐的方式是为每个特性区提供它自己的路由配置文件。 我们推荐的方式是为每个特性区创建它自己的路由配置文件。
Create a new `hero.routes.ts` in the `heroes` folder like this: Create a new `hero.routes.ts` in the `heroes` folder like this:
@ -1160,7 +1160,7 @@ figure.image-display
We import the two components from their new locations in the `app/heroes/` folder, define the two hero routes. We import the two components from their new locations in the `app/heroes/` folder, define the two hero routes.
and add them to an exported `HeroesRoutes` array. and add them to an exported `HeroesRoutes` array.
我们从位于`app/heroes/`目录下导入这两个组件,用它们定义两个英雄路由,把它们加入到`HeroesRoutes`数组中并导出 从它们所在的新`app/heroes/`目录导入列表和详情组件,定义两个英雄路由并导出到`HeroesRoutes`数组
### Route definition with a parameter ### Route definition with a parameter
@ -1168,7 +1168,7 @@ figure.image-display
The route to `HeroDetailComponent` has a twist. The route to `HeroDetailComponent` has a twist.
`HeroDetailComponent`的路由有点特殊。 `HeroDetailComponent`的路由有点特殊。
+makeExample('router/ts/app/heroes/heroes.routes.ts','hero-detail-route')(format=".") +makeExample('router/ts/app/heroes/heroes.routes.ts','hero-detail-route')(format=".")
@ -1181,7 +1181,7 @@ figure.image-display
If we tell the router to navigate to the detail component and display "Magneta", we expect hero `id` (15) to appear in the If we tell the router to navigate to the detail component and display "Magneta", we expect hero `id` (15) to appear in the
browser URL like this: browser URL like this:
如果要告诉路由器导航到这个详情组件并让它显示“Magneta”我们会期望这个英雄的`id`15像这样显示在浏览器的URL中 如果要告诉路由器导航到详情组件并让它显示“Magneta”我们会期望这个英雄的`id`15像这样显示在浏览器的URL中
code-example(format="." language="bash"). code-example(format="." language="bash").
localhost:3000/hero/15 localhost:3000/hero/15
@ -1190,7 +1190,7 @@ code-example(format="." language="bash").
If a user enters that URL into the browser address bar, the router should recognize the If a user enters that URL into the browser address bar, the router should recognize the
pattern and go to the same "Magneta" detail view. pattern and go to the same "Magneta" detail view.
如果用户把此URL输入到浏览器的地址栏中路由器就会识别出这种模式同样也会进入“Magneta”的详情视图。 如果用户把此URL输入到浏览器的地址栏中路由器就会识别出这种模式同样进入“Magneta”的详情视图。
.l-sub-section .l-sub-section
@ -1204,11 +1204,12 @@ code-example(format="." language="bash").
the value `15` in the path clearly distinguishes the route to "Magneta" from the value `15` in the path clearly distinguishes the route to "Magneta" from
a route for some other hero. a route for some other hero.
在这个场景下,把路由参数的令牌`:id`嵌入到路由定义的`path`中是一个好主意,因为对于`HeroDetailComponent`来说`id`是*必须的*,而且路径中的值`15`已经足够把到“Magneta”的路由和到其它英雄的路由明确区分开。 在这个场景下,把路由参数的令牌`:id`嵌入到路由定义的`path`中是一个好主意,因为对于`HeroDetailComponent`来说`id`是*必须的*
而且路径中的值`15`已经足够把到“Magneta”的路由和到其它英雄的路由明确区分开。
A [query parameter](#query-parameter) might be a better choice if we were passing an *optional* value to `HeroDetailComponent`. A [query parameter](#query-parameter) might be a better choice if we were passing an *optional* value to `HeroDetailComponent`.
如果我们要往`HeroDetailComponent`中传入一个*可选*值,那么[查询参数](#query-parameter)可能会是一个更好的选择。 如果要往`HeroDetailComponent`中传入一个*可选*值,那么[查询参数](#query-parameter)可能会是一个更好的选择。
h3#merge-hero-routes Merge hero routes into application routes h3#merge-hero-routes Merge hero routes into application routes
@ -1240,13 +1241,13 @@ h3#merge-hero-routes 把英雄区的路由合并到应用程序的路由中
It won't change as we evolve the hero feature with more components and different routes. It won't change as we evolve the hero feature with more components and different routes.
That's a key benefit of creating a separate route configuration for each feature area. That's a key benefit of creating a separate route configuration for each feature area.
这样做的结果是,`app.routes.ts`文件不用再了解“英雄”特性区的具体知识:组件的细节、路由的细节等等。 这样做的结果是,`app.routes.ts`文件不用再了解“英雄”特性区的具体知识,比如组件细节和路由细节等等。
这样,当我们要为英雄特性区加入更多的组件和路由,对它进行演进时,该文件将不用做任何变化。 这样,当我们要为英雄特性区加入更多的组件和路由,对它进行演进时,该文件将不用做任何变化。
因此,为每个特性区单独创建路由配置是一个关键性的优点。 这真是为每个特性区单独创建路由配置的关键性优点。
h3#navigate Navigate to hero detail imperatively h3#navigate Navigate to hero detail imperatively
h3#navigate 强制导航到英雄详情 h3#navigate 命令式地导航到英雄详情
:marked :marked
*We won't navigate to the detail component by clicking a link* *We won't navigate to the detail component by clicking a link*
@ -1257,12 +1258,12 @@ h3#navigate 强制导航到英雄详情
Instead, when the user *clicks* a hero in the list, we'll *command* the router Instead, when the user *clicks* a hero in the list, we'll *command* the router
to navigate to the hero detail view for the selected hero. to navigate to the hero detail view for the selected hero.
要怎样呢?当用户在列表中*点击*一个英雄时,我们将*命令*路由器导航到所选英雄的详情视图。 取而代之,当用户在列表中*点击*一个英雄时,我们将*命令*路由器导航到所选英雄的详情视图。
We'll adjust the `HeroListComponent` to implement these tasks, beginning with its constructor We'll adjust the `HeroListComponent` to implement these tasks, beginning with its constructor
which acquires the router service and the `HeroService` by dependency injection: which acquires the router service and the `HeroService` by dependency injection:
我们将调整`HeroListComponent`来实现这些任务。先从构造函数开始改:它通过依赖注入系获得路由服务和`HeroService`服务。 我们将调整`HeroListComponent`来实现这些任务。先从构造函数开始改:它通过依赖注入系获得路由服务和`HeroService`服务。
+makeExample('router/ts/app/heroes/hero-list.component.1.ts','ctor', 'app/heroes/hero-list.component.ts (Constructor)')(format=".") +makeExample('router/ts/app/heroes/hero-list.component.1.ts','ctor', 'app/heroes/hero-list.component.ts (Constructor)')(format=".")
@ -1299,7 +1300,7 @@ h3#route-parameters 在列表视图中设置路由参数
We're navigating to the `HeroDetailComponent` where we expect to see the details of the selected hero. We're navigating to the `HeroDetailComponent` where we expect to see the details of the selected hero.
We'll need *two* pieces of information: the destination and the hero's `id`. We'll need *two* pieces of information: the destination and the hero's `id`.
我们正在导航到`HeroDetailComponent`组件。在那里,我们期望看到所选英雄的详情,这需要两部分信息:导航目标和该英雄的`id`。 我们导航到`HeroDetailComponent`组件。在那里,我们期望看到所选英雄的详情,这需要两部分信息:导航目标和该英雄的`id`。
Accordingly, the *link parameters array* has *two* items: the **path** of the destination route and a **route parameter** that specifies the Accordingly, the *link parameters array* has *two* items: the **path** of the destination route and a **route parameter** that specifies the
`id` of the selected hero. `id` of the selected hero.
@ -1311,7 +1312,7 @@ h3#route-parameters 在列表视图中设置路由参数
:marked :marked
The router composes the appropriate two-part destination URL from this array: The router composes the appropriate two-part destination URL from this array:
路由器从该数组中组合出一个合适的两段式目标URL 路由器从该数组中组合出一个合适的两段式目标URL
code-example(format="." language="bash"). code-example(format="." language="bash").
localhost:3000/hero/15 localhost:3000/hero/15
@ -1349,7 +1350,7 @@ a#hero-detail-ctor
tell the `HeroService` to fetch the hero with that `id`. We'll keep a reference to this `Subscription` so we can tell the `HeroService` to fetch the hero with that `id`. We'll keep a reference to this `Subscription` so we can
tidy things up later. tidy things up later.
然后,再看看`ngOnInit`方法。 然后,在`ngOnInit`方法中,
我们用`ActivatedRoute`服务来接收本路由的参数。 我们用`ActivatedRoute`服务来接收本路由的参数。
由于这些参数是作为`Observable`可观察对象提供的所以我们_订阅`subscribe`_它们通过名字引用`id`参数,并告诉`HeroService`获取指定`id`的英雄。 由于这些参数是作为`Observable`可观察对象提供的所以我们_订阅`subscribe`_它们通过名字引用`id`参数,并告诉`HeroService`获取指定`id`的英雄。
我们还要保存这个`Subscription`(订阅的返回值)的引用,供后面做清理工作。 我们还要保存这个`Subscription`(订阅的返回值)的引用,供后面做清理工作。
@ -1379,7 +1380,7 @@ a#hero-detail-ctor
我们最终还是会从这里导航到外面。那时候路由器将从DOM中移除这个组件并销毁它。 我们最终还是会从这里导航到外面。那时候路由器将从DOM中移除这个组件并销毁它。
在此之前,我们还得自己做一些清理工作。 在此之前,我们还得自己做一些清理工作。
特别是,我们**必须**在Angular销毁此组件之前进行**反订阅(`unsubscribe`***否则会导致内存泄露*。 特别是,我们**必须**在Angular销毁此组件之前进行**反订阅(`unsubscribe`***否则可能会导致内存泄露*。
We unsubscribe from our `Observable` in the `ngOnDestroy` method. We unsubscribe from our `Observable` in the `ngOnDestroy` method.
@ -1475,7 +1476,7 @@ h4#snapshot <i>快照</i>不需要可观察no-observable时的替代方
**记住:**用这种技巧我们只得到了这些参数的_初始_值。 **记住:**用这种技巧我们只得到了这些参数的_初始_值。
如果有可能连续多次导航到此组件,那么就该用`params`可观察对象的方式。 如果有可能连续多次导航到此组件,那么就该用`params`可观察对象的方式。
我们只会在这种情况下使用`params`可观察对象策略 我们在这里选择使用`params`可观察对象策略,以防万一
h3#nav-to-list Navigating back to the list component h3#nav-to-list Navigating back to the list component
@ -1515,7 +1516,7 @@ h3#nav-to-list 导航回列表组件
* navigate imperatively from one component to another * navigate imperatively from one component to another
* 从一个组件强制导航到另一个 * 命令式的从一个组件导航到另一个
* pass information along in route parameters and subscribe to them in our component * pass information along in route parameters and subscribe to them in our component