first review of set-document-title.jade.

This commit is contained in:
Zhimin(Rex) YE 2016-05-15 23:00:09 +01:00
parent 74b13f5f60
commit 80c9768d84
1 changed files with 20 additions and 14 deletions

View File

@ -5,11 +5,12 @@ a(id='top')
Our app should be able to make the browser title bar say whatever we want it to say. Our app should be able to make the browser title bar say whatever we want it to say.
This cookbook explains how to do it. This cookbook explains how to do it.
我们的应用程序应该能让浏览器标题栏显示我们想要它显示的内容。本*食谱*解释怎么做。 应用程序应该能让浏览器标题栏显示我们想要它显示的内容。本*食谱*解释怎么做。
:marked :marked
**See the [live example](/resources/live-examples/cb-set-document-title/ts/plnkr.html)**. **See the [live example](/resources/live-examples/cb-set-document-title/ts/plnkr.html)**.
**参见[在线例子](/resources/live-examples/cb-set-document-title/ts/plnkr.html)**. **参见[在线例子](/resources/live-examples/cb-set-document-title/ts/plnkr.html)**.
.l-sub-section .l-sub-section
img(src='/resources/images/devguide/plunker-separate-window-button.png' alt="pop out the window" align="right" style="margin-right:-20px") img(src='/resources/images/devguide/plunker-separate-window-button.png' alt="pop out the window" align="right" style="margin-right:-20px")
:marked :marked
@ -25,6 +26,7 @@ a(id='top')
The obvious approach is to bind a property of the component to the HTML `<title>` like this: The obvious approach is to bind a property of the component to the HTML `<title>` like this:
最显然的方法是绑定一个组件属性到HTML的`<title>`标签上,像这样: 最显然的方法是绑定一个组件属性到HTML的`<title>`标签上,像这样:
code-example(format='') code-example(format='')
&lt;title&gt;{{This_Does_Not_Work}}&lt;/title&gt; &lt;title&gt;{{This_Does_Not_Work}}&lt;/title&gt;
:marked :marked
@ -32,12 +34,13 @@ code-example(format='')
The root component of our application is an element contained within the `<body>` tag. The root component of our application is an element contained within the `<body>` tag.
The HTML `<title>` is in the document `<head>`, outside the body, making it inaccessible to Angular data binding. The HTML `<title>` is in the document `<head>`, outside the body, making it inaccessible to Angular data binding.
对不起,但是这样不行。我们应用程序的是一个被包含在`<body>`标签的元素。该HTML`<title>`在文档的`<head>`元素里,在主体类容之外,这样Angular的数据绑定无法访问它。 对不起,但是这样不行。我们应用程序的是一个被包含在`<body>`标签的元素。该HTML`<title>`在文档的`<head>`元素里,在主体内容之外,Angular的数据绑定无法访问它。
We could grab the browser `document` object and set the title manually. We could grab the browser `document` object and set the title manually.
That's dirty and undermines our chances of running the app outside of a browser someday. That's dirty and undermines our chances of running the app outside of a browser someday.
我们可以得到浏览器的`document`对象,并且手动设置标题。但是这样不干净,并且把我们将来有一天在浏览器之外运行应用程序的机会给剥夺了。 我们可以得到浏览器的`document`对象,并且手动设置标题。但是这样不干净,并且我们无法在将来在浏览器之外运行应用程序。
.l-sub-section .l-sub-section
:marked :marked
Running your app outside a browser means that you can take advantage of server-side Running your app outside a browser means that you can take advantage of server-side
@ -45,11 +48,12 @@ code-example(format='')
inside a Web Worker to improve your app's responsiveness by using multiple threads. And it inside a Web Worker to improve your app's responsiveness by using multiple threads. And it
means that you could run your app inside Electron.js or Windows Universal to deliver it to the desktop. means that you could run your app inside Electron.js or Windows Universal to deliver it to the desktop.
在浏览器之外运行你的应用程序的意思是你利用服务器端预先渲染,实现几乎即时的第一应用程序渲染时间同时支持SEO搜索引擎优化。它意味着你可以在一个 在浏览器之外运行应用程序的意思是:利用服务器端预先渲染实现几乎即时的第一应用程序渲染时间同时支持SEO搜索引擎优化。它意味着你可以在一个
Web Worker中运行你的应用程序通过使用多个线程增强应用程序的响应性。并且它还意味着你可以在Electron.js或者Windows Universal里面运行发布给桌面环境 Web Worker中运行你的应用程序通过使用多个线程增强应用程序的响应性。它还意味着你可以在Electron.js或者Windows Universal里面运行发布给桌面环境
:marked :marked
## Use the *Title* service ## Use the *Title* service
## 使用*Title*服务 ## 使用*Title*服务
Fortunately, Angular 2 bridges the gap by providing a `Title` service as part of the *Browser platform*. Fortunately, Angular 2 bridges the gap by providing a `Title` service as part of the *Browser platform*.
@ -57,7 +61,7 @@ code-example(format='')
for getting and setting the current HTML document title: for getting and setting the current HTML document title:
幸运的是Angular 2在*Browser platform*包中,提供了一个`Title`服务,桥接这个间隔。 幸运的是Angular 2在*Browser platform*包中,提供了一个`Title`服务,桥接这个间隔。
[Title](../api/platform/browser/Title-class.html)服务是一个简单地类提供了一个API用来获取和设置当前HTML文档的标题。 [Title](../api/platform/browser/Title-class.html)服务是一个简单地类提供了一个API用来获取和设置当前HTML文档的标题。
* `getTitle() : string` &mdash; Gets the title of the current HTML document. * `getTitle() : string` &mdash; Gets the title of the current HTML document.
@ -73,31 +77,32 @@ code-example(format='')
function, we'll also have to include `Title` service explicitly as one of the bootstrap providers: function, we'll also have to include `Title` service explicitly as one of the bootstrap providers:
虽然该类是Browser platform包的一部分它*不是*Angular自动默认装载的*Browser platform providers的一部分*。 虽然该类是Browser platform包的一部分它*不是*Angular自动默认装载的*Browser platform providers的一部分*。
这意味着我们在使用Browser platform的`bootstrap()`函数来引导我们的应用程序时,我们必须要明确地把`Title`服务作为引导的providers之一加入进来: 这意味着我们在使用Browser platform的`bootstrap()`函数来引导我们的应用程序时,我们必须要明确地把`Title`服务作为引导的供应商之一加入进来:
+makeExample( "cb-set-document-title/ts/app/main.ts", "bootstrap-title", "app/main.ts (provide Title service)" )(format='.') +makeExample( "cb-set-document-title/ts/app/main.ts", "bootstrap-title", "app/main.ts (provide Title service)" )(format='.')
:marked :marked
Once we've explicitly provided the `Title` service we can then inject the `Title` service into any of our Once we've explicitly provided the `Title` service we can then inject the `Title` service into any of our
custom application components and services. custom application components and services.
一旦我们明确的提供了`Title`服务,我们就能把`Title`服务注入到任何一个我们自定义的应用程序组件和服务里面。 一旦我们明确的提供了`Title`服务,我们就能把`Title`服务注入到任何一个应用程序组件和服务里面。
Let's inject the `Title` service into the root `AppComponent` and expose a bindable `setTitle` method that calls it: Let's inject the `Title` service into the root `AppComponent` and expose a bindable `setTitle` method that calls it:
让我们把`Title`服务注入到根`AppComponent`组件,并暴漏一个调用该服务的,可以绑定的`setTitle`方法: 让我们把`Title`服务注入到根`AppComponent`组件,并暴漏可以绑定的`setTitle`方法来调用该服务
+makeExample( "cb-set-document-title/ts/app/app.component.ts", "class", "app/app.component.ts (class)" )(format='.') +makeExample( "cb-set-document-title/ts/app/app.component.ts", "class", "app/app.component.ts (class)" )(format='.')
:marked :marked
We bind that method to three anchor tags and, voilà! We bind that method to three anchor tags and, voilà!
我们绑定这个方法到三个锚标签,瞧瞧! 我们绑定这个方法到三个锚标签,瞧瞧!
figure.image-display figure.image-display
img(src="/resources/images/cookbooks/set-document-title/set-title-anim.gif" alt="Set title") img(src="/resources/images/cookbooks/set-document-title/set-title-anim.gif" alt="Set title")
:marked :marked
Here's the complete solution Here's the complete solution
这里是一个完整的方案(代码)。 这里是完整的方案(代码)。
+makeTabs( +makeTabs(
`cb-set-document-title/ts/app/main.ts, `cb-set-document-title/ts/app/main.ts,
@ -115,10 +120,12 @@ figure.image-display
.l-main-section .l-main-section
:marked :marked
## Why we provide the *Title* service in *bootstrap* ## Why we provide the *Title* service in *bootstrap*
## 我们为什么提供在*bootstrap*里面这个*Title*服务
## 我们为什么在*bootstrap*里面提供这个*Title*服务
We generally recommended providing application-wide services in the root application component, `AppComponent`. We generally recommended providing application-wide services in the root application component, `AppComponent`.
我们一般推荐在应用程序根组件`AppComponent`提供应用程序全范围服务。 我们一般推荐在应用程序根组件`AppComponent`提供应用程序全范围服务。
Here we recommend registering the title service during bootstrapping, Here we recommend registering the title service during bootstrapping,
a location we reserve for configuring the runtime Angular enviroment. a location we reserve for configuring the runtime Angular enviroment.
@ -131,8 +138,7 @@ figure.image-display
we'll have to provide a different `Title` service that understands the concept of a "document title" for that specific platform. we'll have to provide a different `Title` service that understands the concept of a "document title" for that specific platform.
Ideally the application itself neither knows nor cares about the runtime environment. Ideally the application itself neither knows nor cares about the runtime environment.
这正好是我们在做的。该`Title`服务是Angular *browser platform*的一部分。如果我们在另一个不同的平台上引导我们的应用程序,我们将会提供一个不同的`Title`服务,该服务能 这正好是我们要做的。`Title`服务是Angular *browser platform*的一部分。如果我们在另一个不同的平台上引导我们的应用程序,我们将会提供一个不同的,专门为这个平台准备的`Title`服务。
明白这个指定平台的"文档标题"概念。
:marked :marked
[Back to top](#top) [Back to top](#top)