first review of set-document-title.jade.
This commit is contained in:
parent
74b13f5f60
commit
80c9768d84
|
@ -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='')
|
||||||
<title>{{This_Does_Not_Work}}</title>
|
<title>{{This_Does_Not_Work}}</title>
|
||||||
: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` — Gets the title of the current HTML document.
|
* `getTitle() : string` — 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)
|
||||||
|
|
||||||
|
|
Loading…
Reference in New Issue