review: ngmodule.jade to line 700

This commit is contained in:
Zhimin YE (Rex) 2016-09-15 16:56:39 +01:00
parent df5bf89fa3
commit 35a1cce5dc
1 changed files with 31 additions and 37 deletions

View File

@ -16,17 +16,17 @@ block includes
It may add service providers to the application dependency injectors. It may add service providers to the application dependency injectors.
And there are more options covered here. And there are more options covered here.
Angular模块是一个带有**@NgModule**装饰器函数的_类_。 Angular模块是一个带有**@NgModule**装饰器函数的_类_。
`@NgModule`接收一个元数据对象该对象告诉Angular如何编译和运行模块代码。 `@NgModule`接收一个元数据对象该对象告诉Angular如何编译和运行模块代码。
它标记出该模块_拥有_的组件、指令和管道 它标记出该模块_拥有_的组件、指令和管道
把它们公开出去,以便外部组件使用它们。 把它们的一部分公开出去,以便外部组件使用它们。
它可以向应用的依赖注入器中添加服务提供商。 它可以向应用的依赖注入器中添加服务提供商。
还会涉及到更多选项。 还会涉及到更多选项。
This page explains how to **create** `NgModule` classes and how to load them, This page explains how to **create** `NgModule` classes and how to load them,
either immediately when the application launches or later, as needed, via the [Router](router.html). either immediately when the application launches or later, as needed, via the [Router](router.html).
页面将会讲解如何**创建**`NgModule`类,以及如何加载它们 —— 无论是在程序启动时立即加载,还是稍后由[路由器](router.html)按需加载。 章将会讲解如何**创建**`NgModule`类,以及如何加载它们 —— 可以在程序启动时立即加载,也可以稍后由[路由器](router.html)按需加载。
## Table of Contents ## Table of Contents
@ -61,14 +61,11 @@ block includes
* [NgModule metadata properties](#ngmodule-properties "A technical summary of the @NgModule metadata properties") * [NgModule metadata properties](#ngmodule-properties "A technical summary of the @NgModule metadata properties")
* [NgModule元数据的属性](#ngmodule-properties "对@NgModule元数据属性的技术性总结") * [NgModule元数据的属性](#ngmodule-properties "对@NgModule元数据属性的技术性总结")
### Live examples
### 在线例子 ### 在线例子
This page explains Angular Modules through a progression of improvements to a sample with a "Tour of Heroes" theme. This page explains Angular Modules through a progression of improvements to a sample with a "Tour of Heroes" theme. Here's an index to live examples at key moments in the evolution of that sample:
Here's an index to live examples at key moments in the evolution of that sample:
此页面通过一个基于《英雄指南》的渐进式例子解释了Angular的模块。 此页面通过一个基于《英雄指南》的渐进式例子解释了Angular的模块。这里是例子演化过程中一些关键节点的在线例子。
这里是例子演化过程中一些关键节点的在线例子。
* <live-example plnkr="minimal.0">A minimal NgModule app</live-example> * <live-example plnkr="minimal.0">A minimal NgModule app</live-example>
* <live-example plnkr="minimal.0">最小化的NgModule应用</live-example> * <live-example plnkr="minimal.0">最小化的NgModule应用</live-example>
@ -93,8 +90,8 @@ block includes
offers ready answers to specific design and implementation questions. offers ready answers to specific design and implementation questions.
Read this page first before hopping over to those FAQs. Read this page first before hopping over to those FAQs.
烹饪宝典中的[Angular模块常见问题](../cookbook/ngmodule-faq.html "Angular模块常见问题")为一些与设计实现有关的问题提供了答案。 烹饪宝典中的[Angular模块常见问题](../cookbook/ngmodule-faq.html "Angular模块常见问题")为一些与设计实现有关的问题提供了答案。
不过在阅读FAQ之前,要先阅读此页面。 不过在阅读常见问题之前,要先阅读此页面。
.l-hr .l-hr
@ -124,7 +121,7 @@ a#angular-modularity
cohesive blocks of functionality, each focused on a cohesive blocks of functionality, each focused on a
feature area, application business domain, workflow, or common collection of utilities. feature area, application business domain, workflow, or common collection of utilities.
Angular模块把组件、指令和管道打包成内聚的功能块一个都聚焦于一个特性分区、业务领域、工作流,或一组通用的工具。 Angular模块把组件、指令和管道打包成内聚的功能块聚焦于一个特性分区、业务领域、工作流,或一组通用的工具。
Modules can also add services to the application. Modules can also add services to the application.
Such services might be internally-developed such as the application logger. Such services might be internally-developed such as the application logger.
@ -151,7 +148,7 @@ a#angular-modularity
* import other modules with the components, directives and pipes needed by the components in _this_ module. * import other modules with the components, directives and pipes needed by the components in _this_ module.
* 导入其它模块,获得本模块所需的组件、指令和管道。 * 导入其它模块,从其他模块总获得本模块所需的组件、指令和管道。
* provide services at the application level that any application component can use. * provide services at the application level that any application component can use.
@ -168,12 +165,12 @@ a#angular-modularity
We then import these modules into the _root module_. We then import these modules into the _root module_.
对于组件很少的简单应用来说只用一个_根模块_就足够了。 对于组件很少的简单应用来说只用一个_根模块_就足够了。
随着应用规模的增长,我们逐步把_根模块_重构成一些**特性模块**,它们用来实现一组密切相关的功能。 随着应用规模的增长,我们逐步从_根模块_中重构出一些**特性模块**,它们用来实现一组密切相关的功能。
然后我们在_根模块_中导入它们。 然后我们在_根模块_中导入它们。
We'll see how later in the page. Let's start with the _root module_. We'll see how later in the page. Let's start with the _root module_.
稍后我们就会看到怎么做。不过我们还是先从_根模块_开始吧 稍后我们就会看到怎么做。不过还是先从_根模块_开始吧
a#root_module a#root_module
.l-main-section .l-main-section
@ -190,7 +187,7 @@ a#root_module
This `AppModule` is about as minimal as it gets: This `AppModule` is about as minimal as it gets:
这个最小化的`AppModule`是这样的: 最小化的`AppModule`是这样的:
+makeExample('ngmodule/ts/app/app.module.0.ts', '', 'app/app.module.ts (minimal)')(format=".") +makeExample('ngmodule/ts/app/app.module.0.ts', '', 'app/app.module.ts (minimal)')(format=".")
@ -219,7 +216,7 @@ a#root_module
The example `AppComponent` simply displays a data-bound title: The example `AppComponent` simply displays a data-bound title:
这个范例`AppComponent`只会显示出一个被绑定的标题: 下面范例`AppComponent`显示被绑定的标题:
+makeExample('ngmodule/ts/app/app.component.0.ts', '', 'app/app.component.ts (minimal)')(format=".") +makeExample('ngmodule/ts/app/app.component.0.ts', '', 'app/app.component.ts (minimal)')(format=".")
:marked :marked
@ -245,7 +242,7 @@ a#bootstrap
In this page we consider two options, both targeting the browser. In this page we consider two options, both targeting the browser.
针对不同的平台Angular提供了很多引导选项。 针对不同的平台Angular提供了很多引导选项。
页面我们只讲两个选项,都是针对浏览器平台的。 我们只讲两个选项,都是针对浏览器平台的。
### Dynamic bootstrapping with the Just-in-time (JiT) compiler ### Dynamic bootstrapping with the Just-in-time (JiT) compiler
@ -265,8 +262,6 @@ a#bootstrap
<live-example embedded plnkr="minimal.0" img="devguide/ngmodule/minimal-plunker.png">Try the live example.</live-example> <live-example embedded plnkr="minimal.0" img="devguide/ngmodule/minimal-plunker.png">Try the live example.</live-example>
<live-example embedded plnkr="minimal.0" img="devguide/ngmodule/minimal-plunker.png">试试在线例子。</live-example>
### Static bootstrapping with the Ahead-of-time (AoT) compiler ### Static bootstrapping with the Ahead-of-time (AoT) compiler
### 使用预先编译器AoT - Ahead-Of-Time进行静态引导 ### 使用预先编译器AoT - Ahead-Of-Time进行静态引导
@ -298,7 +293,7 @@ a#bootstrap
The application code downloaded to the browser is much smaller than the dynamic equivalent The application code downloaded to the browser is much smaller than the dynamic equivalent
and it is ready to execute immediately. The performance boost can be significant. and it is ready to execute immediately. The performance boost can be significant.
下载到浏览器中的应用代码比动态版本要小得多,并且能立即执行。引导的性能得到显著提升。 下载到浏览器中的应用代码比动态版本要小得多,并且能立即执行。引导的性能可以得到显著提升。
Both the JiT and AoT compilers generate an `AppModuleNgFactory` class from the same `AppModule` Both the JiT and AoT compilers generate an `AppModuleNgFactory` class from the same `AppModule`
source code. source code.
@ -312,7 +307,7 @@ a#bootstrap
In general, the `AppModule` should neither know nor care how it is bootstrapped. In general, the `AppModule` should neither know nor care how it is bootstrapped.
通常,`AppModule`不必关心它将被如何引导 通常,`AppModule`不必关心它是如何被引导的
Although the `AppModule` evolves as the app grows, the bootstrap code in `main.ts` doesn't change. Although the `AppModule` evolves as the app grows, the bootstrap code in `main.ts` doesn't change.
This is the last time we'll look at `main.ts`. This is the last time we'll look at `main.ts`.
@ -348,7 +343,7 @@ a#declarations
If we ran the app now, Angular would not recognize the `highlight` attribute and would ignore it. If we ran the app now, Angular would not recognize the `highlight` attribute and would ignore it.
We must declare the directive in `AppModule`. We must declare the directive in `AppModule`.
如果我们现在就运行该应用Angular将无法识别`highlight`属性,而是会忽略它。 如果我们现在就运行该应用Angular将无法识别`highlight`属性,并且忽略它。
我们必须在`AppModule`中声明该指令。 我们必须在`AppModule`中声明该指令。
Import the `HighlightDirective` class and add it to the module's `declarations` like this: Import the `HighlightDirective` class and add it to the module's `declarations` like this:
@ -365,7 +360,7 @@ a#declarations
We decide to refactor the title into its own `TitleComponent`. We decide to refactor the title into its own `TitleComponent`.
The component's template binds to the component's `title` and `subtitle` properties like this: The component's template binds to the component's `title` and `subtitle` properties like this:
我们打算把标题重构进独立的`TitleComponent`中去 我们决定将标题重构到独立的`TitleComponent`中
该组件的模板绑定到了组件的`title`和`subtitle`属性中,就像这样: 该组件的模板绑定到了组件的`title`和`subtitle`属性中,就像这样:
+makeExample('ngmodule/ts/app/title.component.html', 'v1', 'app/title.component.html')(format=".") +makeExample('ngmodule/ts/app/title.component.html', 'v1', 'app/title.component.html')(format=".")
@ -439,7 +434,7 @@ a#providers
We've _defined_ and _used_ the service. Now we _provide_ it for all components to use by We've _defined_ and _used_ the service. Now we _provide_ it for all components to use by
adding it to a `providers` property in the `AppModule` metadata: adding it to a `providers` property in the `AppModule` metadata:
我们已经_定义_并_使用了_该服务。现在我们通过把它加入`AppModule`元数据的`providers`属性来把它_提供_给所有组件使用。 我们已经_定义_并_使用了_该服务。现在我们通过把它加入`AppModule`元数据的`providers`属性中,来把它_提供_给所有组件使用。
+makeExample('ngmodule/ts/app/app.module.1.ts', 'providers', 'app/app.module.ts (providers)')(format=".") +makeExample('ngmodule/ts/app/app.module.1.ts', 'providers', 'app/app.module.ts (providers)')(format=".")
@ -470,7 +465,7 @@ a#imports
Angular _does_ recognize `NgIf` because we imported it earlier. Angular _does_ recognize `NgIf` because we imported it earlier.
The initial version of `AppModule` imports `BrowserModule`. The initial version of `AppModule` imports `BrowserModule`.
Angular能识别`NfIf`指令,是因为我们以前导入过它。最初版本的`AppModule`就导入了`BrowserModule`。 Angular能识别`NgIf`指令,是因为我们以前导入过它。最初版本的`AppModule`就导入了`BrowserModule`。
+makeExample('ngmodule/ts/app/app.module.0.ts', 'imports', 'app/app.module.ts (imports)')(format=".") +makeExample('ngmodule/ts/app/app.module.0.ts', 'imports', 'app/app.module.ts (imports)')(format=".")
@ -532,23 +527,23 @@ a#imports
[_template-driven form_](forms.html) style or [_template-driven form_](forms.html) style or
the [_reactive form_](../cookbook/dynamic-form.html) style. the [_reactive form_](../cookbook/dynamic-form.html) style.
我们写Angular表单组件时或者使用[_模板驱动式表单_](forms.html) 我们写Angular表单组件时可以使用[_模板驱动式表单_](forms.html)
或者使用[_响应式表单_](../cookbook/dynamic-form.html)。 也可以使用[_响应式表单_](../cookbook/dynamic-form.html)。
This sample is about to import the `FormsModule` from `@angular/forms` because This sample is about to import the `FormsModule` from `@angular/forms` because
the `ContactComponent` is written in the _template-driven_ style. the `ContactComponent` is written in the _template-driven_ style.
Modules with components written in the _reactive_ style, Modules with components written in the _reactive_ style,
should import the `ReactiveFormsModule` instead. should import the `ReactiveFormsModule` instead.
该例子中从`@angular/forms`中导入了`FormsModule`,这是因为`ContactComponent`组件用的是_模板驱动式_ 该例子中从`@angular/forms`中导入了`FormsModule`,这是因为`ContactComponent`组件用的是_模板驱动式表单_。
那些带有_响应式表单_组件的模块应该转而导入`ReactiveFormsModule` 那些带有_响应式表单_组件的模块应该转而导入`ReactiveFormsModule`。
:marked :marked
The `ContactComponent` selector matches an element named `<app-contact>`. The `ContactComponent` selector matches an element named `<app-contact>`.
Add an element with that name to the `AppComponent` template just below the `<app-title>`: Add an element with that name to the `AppComponent` template just below the `<app-title>`:
`ContactComponent`的选择器会去匹配名叫`<app-contact>`的元素。 `ContactComponent`的选择器会去匹配名叫`<app-contact>`的元素。
在`AppComponent`模板中`<app-title>`的下方添加一个具有此名字的元素: 在`AppComponent`模板中`<app-title>`的下方添加一个具有此名字的元素:
+makeExample('ngmodule/ts/app/app.component.1b.ts', 'template', 'app/app.component.ts (template)')(format=".") +makeExample('ngmodule/ts/app/app.component.1b.ts', 'template', 'app/app.component.ts (template)')(format=".")
@ -559,8 +554,7 @@ a#imports
and an alternative version of the `HighlightDirective`. and an alternative version of the `HighlightDirective`.
`ContactComponent`还有很多事要做。 `ContactComponent`还有很多事要做。
表单组件通常都是很复杂的,而这一个则具有自己的它自己的`ContactService`、 表单组件通常都是很复杂的。本组件具有它自己的`ContactService`和[自定义管道](#pipes.html#custom-pipes) `Awesome`
它自己的[自定义管道](#pipes.html#custom-pipes) `Awesome`
以及`HighlightDirective`的另一个版本。 以及`HighlightDirective`的另一个版本。
To make it manageable, we place all contact-related material in an `app/contact` folder To make it manageable, we place all contact-related material in an `app/contact` folder
@ -605,7 +599,7 @@ a#imports
form features such as validation are not yet available. form features such as validation are not yet available.
退一步说即使Angular有办法识别`ngModel``ContactComponent`也不会表现的像一个Angular表单 退一步说即使Angular有办法识别`ngModel``ContactComponent`也不会表现的像一个Angular表单
因为这里没法使用Form相关的特性比如有效性验证 因为本组件表单的表单相关的特性(比如有效性验证)还不可用
### Import the FormsModule ### Import the FormsModule
@ -633,7 +627,7 @@ a#imports
Components, directives and pipes belong to one module &mdash; and _one module only_. Components, directives and pipes belong to one module &mdash; and _one module only_.
这些指令属于`FormsModule`。 这些指令属于`FormsModule`。
组件、指令和管道应该而且只能属于一个模块。 组件、指令和管道_只能_属于一个模块。
**Never re-declare classes that belong to another module.** **Never re-declare classes that belong to another module.**
@ -686,7 +680,7 @@ a#import-name-conflict
But then it would be scoped to this component _only_. But then it would be scoped to this component _only_.
We want to share this service with other contact-related components that we will surely add later. We want to share this service with other contact-related components that we will surely add later.
我们在某个地方提供该服务。 我们必须在某个地方提供该服务。
在`ContactComponent`中_可以_提供它。 在`ContactComponent`中_可以_提供它。
但是那样一来它的作用范围就会_仅_局限于该组件及其子组件。 但是那样一来它的作用范围就会_仅_局限于该组件及其子组件。
而我们希望让该服务与其它和联系人有关的组件中共享,稍后我们就会添加那些组件。 而我们希望让该服务与其它和联系人有关的组件中共享,稍后我们就会添加那些组件。