fix: 修订完了style-guide中漏翻的部分。

This commit is contained in:
Zhicheng Wang 2017-03-03 17:03:18 +08:00
parent 2a60ad27a7
commit 8f0b8fbf7b
1 changed files with 24 additions and 7 deletions

View File

@ -1945,11 +1945,15 @@ a(href="#toc").to-top 回到顶部
:marked :marked
**Do** declare components, directives, and pipes in a shared module when those **Do** declare components, directives, and pipes in a shared module when those
items will be re-used and referenced by the components declared in other feature modules. items will be re-used and referenced by the components declared in other feature modules.
**坚持**在共享模块中声明那些可能被那些特性模块引用的可复用组件、指令和管道。
.s-rule.consider .s-rule.consider
:marked :marked
**Consider** using the name SharedModule, when the contents of a shared **Consider** using the name SharedModule, when the contents of a shared
module are referenced across the entire application. module are referenced across the entire application.
**考虑**把可能在整个应用中到处引用的模块命名为SharedModule
.s-rule.do .s-rule.do
:marked :marked
@ -2062,6 +2066,8 @@ a(href="#toc").to-top 回到顶部
:marked :marked
**Consider** collecting numerous, auxiliary, single-use classes inside a core module **Consider** collecting numerous, auxiliary, single-use classes inside a core module
to simplify the apparent structure of a feature module. to simplify the apparent structure of a feature module.
**考虑**把那些数量庞大、辅助性的、只用一次的类收集到核心模块中,让特性模块的结构更清晰简明。
.s-rule.consider .s-rule.consider
:marked :marked
@ -2442,33 +2448,42 @@ a(href="#toc").to-top 回到顶部
.s-rule.do .s-rule.do
:marked :marked
**Do** specify _component-relative_ URLs, prefixed with `./`, and add `moduleId: module.id` to the component metadata. **Do** specify _component-relative_ URLs, prefixed with `./`, and add `moduleId: module.id` to the component metadata.
**坚持**指定*相对于模块的* URL ,给它加上`./`前缀,并且往组件元数据中添加 `moduleId: module.id`。
.s-why .s-why
:marked :marked
**Why?** Large, inline templates and styles obscure the component's purpose and implementation, reducing readability and maintainability. **Why?** Large, inline templates and styles obscure the component's purpose and implementation, reducing readability and maintainability.
**为何?**巨大的、内联的模板和样式表会遮盖组件的意图和实现方式,削弱可读性和可维护性。
.s-why .s-why
:marked :marked
**Why?** In most editors, syntax hints and code snippets aren't available when developing inline templates and styles. **Why?** In most editors, syntax hints and code snippets aren't available when developing inline templates and styles.
The Angular TypeScript Language Service (forthcoming) promises to overcome this deficiency for HTML templates The Angular TypeScript Language Service (forthcoming) promises to overcome this deficiency for HTML templates
in those editors that support it; it won't help with CSS styles. in those editors that support it; it won't help with CSS styles.
**为何?**在多数编辑器中,编写内联的模板和样式表时都无法使用语法提示和代码片段功能。
Angular的TypeScript语言服务即将到来可以帮助那些编辑器在编写HTML模板时克服这一缺陷但对CSS样式没有帮助。
.s-why .s-why
:marked :marked
**Why?** A _component relative_ URL requires no change when you move the component files, as long as the files stay together. **Why?** A _component relative_ URL requires no change when you move the component files, as long as the files stay together.
**为何?**当你移动组件文件时相对于组件的URL不需要修改因为这些文件始终会在一起。
.s-why .s-why
:marked :marked
**Why?** The JIT compiler requires the `moduleId` for relative URLs; the AOT compiler, **Why?** The JIT compiler requires the `moduleId` for relative URLs; the AOT compiler,
which doesn't need it, safely ignores this property. which doesn't need it, safely ignores this property.
**为何?**在 (*.js 和 *.ts) 代码里面内联模板时,某些编辑器不支持语法提示 **为何?**JIT编译器需要`moduleId`来确定这些相对URLAOT编译器不需要它而是会忽略此属性
.s-why.s-why-last .s-why.s-why-last
:marked :marked
**Why?** The `./` prefix is standard syntax for relative URLs; don't depend on Angular's current ability to do without that prefix. **Why?** The `./` prefix is standard syntax for relative URLs; don't depend on Angular's current ability to do without that prefix.
**为何?**当没有与内联模板和样式混合时,组件文件中的逻辑更易于阅读 **为何?**`./`前缀是相对URL的标准语法不必依赖Angular的特殊处理如果没有前缀则不行
+makeExample('style-guide/ts/src/05-04/app/heroes/heroes.component.avoid.ts', 'example', 'app/heroes/heroes.component.ts')(avoid=1) +makeExample('style-guide/ts/src/05-04/app/heroes/heroes.component.avoid.ts', 'example', 'app/heroes/heroes.component.ts')(avoid=1)
@ -2556,18 +2571,20 @@ a(href="#toc").to-top 回到顶部
:marked :marked
**Avoid** _input_ and _output_ aliases except when it serves an important purpose. **Avoid** _input_ and _output_ aliases except when it serves an important purpose.
**避免**除非有重要目的,否则不要为输入和输出指定别名。
.s-why .s-why
:marked :marked
**Why?** Two names for the same property (one private, one public) is inherently confusing. **Why?** Two names for the same property (one private, one public) is inherently confusing.
**避免**重命名输入和输出 **为何?**同一个属性有两个名字(一个对内一个对外)很容易导致混淆
.s-why.s-why-last .s-why.s-why-last
:marked :marked
**Why?** You should use an alias when the directive name is also an _input_ property, **Why?** You should use an alias when the directive name is also an _input_ property,
and the directive name doesn't describe the property. and the directive name doesn't describe the property.
**为何?**当指令的输入或输出属性的名字与导出的公共 API 名字不一样时,可能导致混乱 **为何?**如果指令名也同时用作*输入*属性,而且指令名无法准确描述这个属性的用途时,应该使用别名
+makeExample('style-guide/ts/src/05-13/app/heroes/shared/hero-button/hero-button.component.avoid.ts', 'example', 'app/heroes/shared/hero-button/hero-button.component.ts')(avoid=1) +makeExample('style-guide/ts/src/05-13/app/heroes/shared/hero-button/hero-button.component.avoid.ts', 'example', 'app/heroes/shared/hero-button/hero-button.component.ts')(avoid=1)
@ -3062,12 +3079,14 @@ a(href="#toc").to-top 回到顶部
**Why?** The details of data management, such as headers, HTTP methods, **Why?** The details of data management, such as headers, HTTP methods,
caching, error handling, and retry logic, are irrelevant to components caching, error handling, and retry logic, are irrelevant to components
and other data consumers. and other data consumers.
**为何?**数据管理的详情,比如头信息、方法、缓存、错误处理和重试逻辑,不是组件和其它的数据消费者应该关心的事情。
A data service encapsulates these details. It's easier to evolve these A data service encapsulates these details. It's easier to evolve these
details inside the service without affecting its consumers. And it's details inside the service without affecting its consumers. And it's
easier to test the consumers with mock service implementations. easier to test the consumers with mock service implementations.
**为何?**数据服务的实现可能有非常具体的代码来处理数据仓库,包括数据头 (headers)、如何与数据交谈或者其它服务 (例如`Http`)。把逻辑分离到数据服务可以将该逻辑封装在一个地方,对外部使用者(例如组件)隐藏具体的实施细节 数据服务应该封装这些细节。这样,在服务内部修改细节,就不会影响到它的消费者。并且更容易通过实现一个模拟服务来对消费者进行测试
a(href="#toc").to-top Back to top a(href="#toc").to-top Back to top
@ -3136,8 +3155,6 @@ a(href="#toc").to-top 回到顶部
:marked :marked
### <a id="A-01"></a>Codelyzer ### <a id="A-01"></a>Codelyzer
### <a id="A-01"></a>Codelyzer
#### <a href="#A-01">Style A-01</a> #### <a href="#A-01">Style A-01</a>
#### <a href="#A-01">风格 A-01</a> #### <a href="#A-01">风格 A-01</a>