Merge branch 'master' of https://github.com/angular/angular-cn
This commit is contained in:
commit
ffe996ee22
|
@ -22,6 +22,3 @@ script.
|
||||||
<!-- Google Feedback -->
|
<!-- Google Feedback -->
|
||||||
script(src="//www.gstatic.com/feedback/api.js" type="text/javascript")
|
script(src="//www.gstatic.com/feedback/api.js" type="text/javascript")
|
||||||
|
|
||||||
<!-- Twitter Widget -->
|
|
||||||
script.
|
|
||||||
(function(d,s,id){var js,fjs=d.getElementsByTagName(s)[0],p=/^http:/.test(d.location)?'http':'https';if(!d.getElementById(id)){js=d.createElement(s);js.id=id;js.src=p+"://platform.twitter.com/widgets.js";fjs.parentNode.insertBefore(js,fjs);}})(document,"script","twitter-wjs");
|
|
||||||
|
|
|
@ -196,7 +196,7 @@ code-example(language="sh" class="code-shell").
|
||||||
By default the tool generates a translation file named **`messages.xlf`** in the
|
By default the tool generates a translation file named **`messages.xlf`** in the
|
||||||
<a href="https://en.wikipedia.org/wiki/XLIFF" target="_blank">XML Localisation Interchange File Format (XLIFF, version 1.2)</a>.
|
<a href="https://en.wikipedia.org/wiki/XLIFF" target="_blank">XML Localisation Interchange File Format (XLIFF, version 1.2)</a>.
|
||||||
|
|
||||||
工具默认生成一个名为**`messages.xlf`**的翻译文件,格式为<a href="https://en.wikipedia.org/wiki/XLIFF" target="_blank">XML本地化互换文件格式(XLIFF, version 1.2)</a>。
|
工具默认生成一个名为**`messages.xlf`**的翻译文件,格式为<a href="https://en.wikipedia.org/wiki/XLIFF" target="_blank">XML本土化互换文件格式(XLIFF, version 1.2)</a>。
|
||||||
|
|
||||||
code-example(language="sh" class="code-shell").
|
code-example(language="sh" class="code-shell").
|
||||||
./node_modules/.bin/ng-xi18n --i18nFormat=xmb
|
./node_modules/.bin/ng-xi18n --i18nFormat=xmb
|
||||||
|
@ -246,64 +246,110 @@ a#translate
|
||||||
:marked
|
:marked
|
||||||
## Translate _le message textuel_
|
## Translate _le message textuel_
|
||||||
|
|
||||||
|
## 翻译
|
||||||
|
|
||||||
The `ng-xi18n` command generated a translation source file in the project root folder named `messages.xlf`.
|
The `ng-xi18n` command generated a translation source file in the project root folder named `messages.xlf`.
|
||||||
The next step is to translate the English language template text into the specific language translation
|
The next step is to translate the English language template text into the specific language translation
|
||||||
files. The cookbook sample creates a French translation file.
|
files. The cookbook sample creates a French translation file.
|
||||||
|
|
||||||
|
`ng-xi18n`命令在项目根目录生成一个名为`messages.xlf`的翻译源文件。
|
||||||
|
下一步是将英文模板文本翻译到目标语言的翻译文件。
|
||||||
|
本烹饪书创建了一个法语翻译文件。
|
||||||
|
|
||||||
a#localization-folder
|
a#localization-folder
|
||||||
:marked
|
:marked
|
||||||
### Create a localization folder
|
### Create a localization folder
|
||||||
|
|
||||||
|
### 新建一个本土化目录
|
||||||
|
|
||||||
You will probably translate into more than one other language so it's a good idea
|
You will probably translate into more than one other language so it's a good idea
|
||||||
for the project structure to reflect your entire internationalization effort.
|
for the project structure to reflect your entire internationalization effort.
|
||||||
|
|
||||||
|
你很有可能翻译到更多其他语言,所以为全部国际化工作做适当的调整项目目录结构是理所当然的。
|
||||||
|
|
||||||
One approach is to dedicate a folder to localization and store related assets
|
One approach is to dedicate a folder to localization and store related assets
|
||||||
(e.g. internationalization files) there.
|
(e.g. internationalization files) there.
|
||||||
|
|
||||||
|
其中一种方法是为本土化和相关资源(比如国际化文件)创建一个专门的目录。
|
||||||
.l-sub-section
|
.l-sub-section
|
||||||
:marked
|
:marked
|
||||||
Localization and internationalization are
|
Localization and internationalization are
|
||||||
<a href="https://en.wikipedia.org/wiki/Internationalization_and_localization" target="_blank">different but closely related terms</a>.
|
<a href="https://en.wikipedia.org/wiki/Internationalization_and_localization" target="_blank">different but closely related terms</a>.
|
||||||
|
|
||||||
|
本土化和国际化是<a href="https://en.wikipedia.org/wiki/Internationalization_and_localization" target="_blank">不同但是很相近的概念</a>。
|
||||||
:marked
|
:marked
|
||||||
This sample follows that suggestion. It has `locale` folder immediately under the project root.
|
This sample follows that suggestion. It has `locale` folder immediately under the project root.
|
||||||
Assets within the folder carry a filename extension that matches a language-culture code from a
|
Assets within the folder carry a filename extension that matches a language-culture code from a
|
||||||
<a href="https://msdn.microsoft.com/en-us/library/ee825488(v=cs.20).aspx" target="_blank">well-known codeset</a>.
|
<a href="https://msdn.microsoft.com/en-us/library/ee825488(v=cs.20).aspx" target="_blank">well-known codeset</a>.
|
||||||
|
|
||||||
|
本例遵循这个建议。项目根目录有`locale`目录。
|
||||||
|
目录的资源的文件名都匹配有一个语言代码后缀,参见<a href="https://msdn.microsoft.com/en-us/library/ee825488(v=cs.20).aspx" target="_blank">语言代码对照表</a>.
|
||||||
|
|
||||||
Move `messages.xlf` into the `locale` folder where it will become the source for all language-specific translations.
|
Move `messages.xlf` into the `locale` folder where it will become the source for all language-specific translations.
|
||||||
Then make a copy for the French language named `messages.fr.xlf` .
|
Then make a copy for the French language named `messages.fr.xlf` .
|
||||||
|
|
||||||
|
将`messages.xlf`移到`locale`目录,这里将存放所有语言与翻译相关的文件。
|
||||||
|
然后为法语复制这个文件,名为`messages.fr.xlf`。
|
||||||
|
|
||||||
Follow the same convention for each target language.
|
Follow the same convention for each target language.
|
||||||
|
|
||||||
|
对所有目标语言都采用同样的约定。
|
||||||
|
|
||||||
### Translate
|
### Translate
|
||||||
|
|
||||||
|
### 翻译
|
||||||
|
|
||||||
In the real world, you send the `messages.fr.xlf` file to a French translator who would fill in the translations
|
In the real world, you send the `messages.fr.xlf` file to a French translator who would fill in the translations
|
||||||
using one of the
|
using one of the
|
||||||
<a href="https://en.wikipedia.org/wiki/XLIFF#Editors" target="_blank">many XLIFF file editors</a>.
|
<a href="https://en.wikipedia.org/wiki/XLIFF#Editors" target="_blank">many XLIFF file editors</a>.
|
||||||
|
|
||||||
|
在现实世界中,`messages.fr.xlf`文件会被发给法语翻译,他们使用<a href="https://en.wikipedia.org/wiki/XLIFF#Editors" target="_blank">这些XLIFF文件编辑器</a>中的一种来翻译它。
|
||||||
|
|
||||||
This sample file is easy to translate without a special editor or knowledge of French.
|
This sample file is easy to translate without a special editor or knowledge of French.
|
||||||
Open `messages.fr.xlf` and find the `<trans-unit>` section:
|
Open `messages.fr.xlf` and find the `<trans-unit>` section:
|
||||||
|
|
||||||
|
我们不需要任何编辑器或者法语知识就可以轻易的翻译本例子文件。
|
||||||
|
打开`messages.fr.xlf`并找到`<trans-unit>`节点:
|
||||||
|
|
||||||
+makeExample('cb-i18n/ts/locale/trans-unit.html', '', 'locale/messages.fr.xlf (<trans-unit>)')(format=".")
|
+makeExample('cb-i18n/ts/locale/trans-unit.html', '', 'locale/messages.fr.xlf (<trans-unit>)')(format=".")
|
||||||
:marked
|
:marked
|
||||||
This XML element represents the translation of the `<h1>` greeting tag you marked with the `i18n` attribute.
|
This XML element represents the translation of the `<h1>` greeting tag you marked with the `i18n` attribute.
|
||||||
|
|
||||||
|
这个XML元素代表了你使用`i18n`属性标记的`<h1>`问候语标签的翻译。
|
||||||
|
|
||||||
Using the _source_, _description_, and _meaning_ elements to guide your translation,
|
Using the _source_, _description_, and _meaning_ elements to guide your translation,
|
||||||
replace the `<target/>` tag with the French greeting:
|
replace the `<target/>` tag with the French greeting:
|
||||||
|
|
||||||
|
翻译中利用_source_、_description_和_meaning_元素的信息,替换`<target/>`标签为法语问候语:
|
||||||
|
|
||||||
+makeExample('cb-i18n/ts/locale/messages.fr.xlf.html', 'trans-unit', 'locale/messages.fr.xlf (<trans-unit>, after translation)')(format=".")
|
+makeExample('cb-i18n/ts/locale/messages.fr.xlf.html', 'trans-unit', 'locale/messages.fr.xlf (<trans-unit>, after translation)')(format=".")
|
||||||
:marked
|
:marked
|
||||||
Note that the `id` is generated by the tool. Don't touch it.
|
Note that the `id` is generated by the tool. Don't touch it.
|
||||||
Its value depends on the content of the message and its assigned meaning.
|
Its value depends on the content of the message and its assigned meaning.
|
||||||
Change either factor and the `id` changes as well.
|
Change either factor and the `id` changes as well.
|
||||||
|
|
||||||
|
注意`id`是工具生成的。不要修改它。
|
||||||
|
它的值取决于两个因素:信息的内容和其指定的含义。
|
||||||
|
改变任何一个因素,`id`就会改变。
|
||||||
.alert.is-helpful
|
.alert.is-helpful
|
||||||
:marked
|
:marked
|
||||||
Repeat the extraction process whenever you add new app messages or edit existing ones.
|
Repeat the extraction process whenever you add new app messages or edit existing ones.
|
||||||
Be careful not to lose the previous translations.
|
Be careful not to lose the previous translations.
|
||||||
Specialized software can help manage the change process.
|
Specialized software can help manage the change process.
|
||||||
|
|
||||||
|
每当你添加或者编辑应用信息,重复提取流程。
|
||||||
|
小心不要丢失之前的翻译。专门的软件可以帮助你管理变更流程。
|
||||||
|
|
||||||
#app-pre-translation
|
#app-pre-translation
|
||||||
:marked
|
:marked
|
||||||
### The app before translation
|
### The app before translation
|
||||||
|
|
||||||
|
### 翻译前的应用程序
|
||||||
|
|
||||||
After the previous steps, the sample app _and_ its translation file are as follows:
|
After the previous steps, the sample app _and_ its translation file are as follows:
|
||||||
|
|
||||||
|
如下所示,是完成前面的步骤后的例子应用**和**它的翻译文件:
|
||||||
|
|
||||||
+makeTabs(`
|
+makeTabs(`
|
||||||
cb-i18n/ts/app/app.component.html,
|
cb-i18n/ts/app/app.component.html,
|
||||||
cb-i18n/ts/app/app.component.ts,
|
cb-i18n/ts/app/app.component.ts,
|
||||||
|
@ -323,136 +369,264 @@ a#merge
|
||||||
:marked
|
:marked
|
||||||
## Merge the completed translation file
|
## Merge the completed translation file
|
||||||
|
|
||||||
|
## 合并已经翻译的文件
|
||||||
|
|
||||||
To merge the translated text into component templates,
|
To merge the translated text into component templates,
|
||||||
you compile the application with the completed translation file.
|
you compile the application with the completed translation file.
|
||||||
The process is the same whether the file is in `.xlf` format or
|
The process is the same whether the file is in `.xlf` format or
|
||||||
in one of the other formats (`.xlif` and `.xtb`) that Angular understands.
|
in one of the other formats (`.xlif` and `.xtb`) that Angular understands.
|
||||||
|
|
||||||
|
要合并已经翻译的文件到组件模板,使用翻译过的文件编译应用。
|
||||||
|
不管文件是`.xlf`格式还是其他Angular接受的格式(`.xlif`和`.xtb`),流程是一样的。
|
||||||
|
|
||||||
You provide the Angular compiler with three new pieces of information:
|
You provide the Angular compiler with three new pieces of information:
|
||||||
|
|
||||||
|
你为Angular编译器提供下列三种新信息:
|
||||||
|
|
||||||
* the translation file
|
* the translation file
|
||||||
* the translation file format
|
|
||||||
|
* 翻译文件
|
||||||
|
|
||||||
|
* the translation file format
|
||||||
|
|
||||||
|
* 翻译文件的格式
|
||||||
|
|
||||||
* the <a href="https://en.wikipedia.org/wiki/XLIFF" target="_blank">_Locale ID_</a>
|
* the <a href="https://en.wikipedia.org/wiki/XLIFF" target="_blank">_Locale ID_</a>
|
||||||
(`fr` or `en-US` for instance)
|
(`fr` or `en-US` for instance)
|
||||||
|
|
||||||
|
* 目标<a href="https://en.wikipedia.org/wiki/XLIFF" target="_blank">_语言环境ID_</a>
|
||||||
|
(例如`fr`或`en-US`)
|
||||||
|
|
||||||
_How_ you provide this information depends upon whether you compile with
|
_How_ you provide this information depends upon whether you compile with
|
||||||
the JiT (_Just-in-Time_) compiler or the AoT (_Ahead-of-Time_) compiler.
|
the JiT (_Just-in-Time_) compiler or the AoT (_Ahead-of-Time_) compiler.
|
||||||
|
|
||||||
|
你如何提供这些信息取决于你使用的是JiT(即时)编译器还是AoT(预先)编译器。
|
||||||
|
|
||||||
* with [JiT](#jit), you provide the information at bootstrap time.
|
* with [JiT](#jit), you provide the information at bootstrap time.
|
||||||
* with [AoT](#aot), you pass the information as `ngc` options.
|
|
||||||
|
* 使用[JiT](#jit)时,在引导时提供
|
||||||
|
|
||||||
|
* with [AoT](#aot), you pass the information as `ngc` options.
|
||||||
|
|
||||||
|
* 使用[AoT](#aot)时,在`ngc`命令的选项里提供
|
||||||
|
|
||||||
a#jit
|
a#jit
|
||||||
.l-main-section
|
.l-main-section
|
||||||
:marked
|
:marked
|
||||||
### Merge with the JiT compiler
|
### Merge with the JiT compiler
|
||||||
|
|
||||||
|
### 用JiT编译器合并
|
||||||
|
|
||||||
The JiT (_Just-in-Time_) compiler compiles the application in the browser as the application loads.
|
The JiT (_Just-in-Time_) compiler compiles the application in the browser as the application loads.
|
||||||
Translation with the JiT compiler is a dynamic process of ...
|
Translation with the JiT compiler is a dynamic process of ...
|
||||||
|
|
||||||
|
JiT(即时)编译器在应用程序加载时,在浏览器中编译应用。
|
||||||
|
在使用JiT编译器的环境中翻译是一个动态的流程,包括:
|
||||||
|
|
||||||
1. determining the language version for the current user,
|
1. determining the language version for the current user,
|
||||||
|
|
||||||
|
1. 决定当前用户的语言,
|
||||||
|
|
||||||
2. importing the appropriate language translation file as a string constant,
|
2. importing the appropriate language translation file as a string constant,
|
||||||
|
|
||||||
|
2. 导入合适的语言翻译文件到一个字符串常量,
|
||||||
|
|
||||||
3. creating corresponding translation providers to guide the JiT compiler,
|
3. creating corresponding translation providers to guide the JiT compiler,
|
||||||
|
|
||||||
|
3. 新建对应的翻译提供商来指导JiT编译器,
|
||||||
|
|
||||||
4. bootstrapping the application with those providers.
|
4. bootstrapping the application with those providers.
|
||||||
|
|
||||||
|
4. 使用这些提供商来启动应用。
|
||||||
|
|
||||||
Open `index.html` and revise the launch script as shown here:
|
Open `index.html` and revise the launch script as shown here:
|
||||||
|
|
||||||
|
打开`index.html`并这样修改加载脚本:
|
||||||
|
|
||||||
+makeExample('cb-i18n/ts/index.html', 'i18n', 'index.html (launch script)')(format='.')
|
+makeExample('cb-i18n/ts/index.html', 'i18n', 'index.html (launch script)')(format='.')
|
||||||
:marked
|
:marked
|
||||||
In this sample, the user's language is hardcoded as a global `document.locale` variable
|
In this sample, the user's language is hardcoded as a global `document.locale` variable
|
||||||
in the `index.html`.
|
in the `index.html`.
|
||||||
|
|
||||||
|
在本例中,用户的语言在`index.html`中被硬编码到一个全局的`document.locale`变量中。
|
||||||
|
|
||||||
a#text-plugin
|
a#text-plugin
|
||||||
:marked
|
:marked
|
||||||
### SystemJS Text plugin
|
### SystemJS Text plugin
|
||||||
|
|
||||||
|
### SystemJS文本插件
|
||||||
|
|
||||||
Notice the SystemJS mapping of `text` to a `systemjs-text-plugin.js`.
|
Notice the SystemJS mapping of `text` to a `systemjs-text-plugin.js`.
|
||||||
With the help of a text pluglin, SystemJS can read any file as raw text and
|
With the help of a text pluglin, SystemJS can read any file as raw text and
|
||||||
return the contents as a string.
|
return the contents as a string.
|
||||||
You'll need it to import the language translation file.
|
You'll need it to import the language translation file.
|
||||||
|
|
||||||
|
注意SystemJS将`text`映射为`systemjs-text-plug.js`。
|
||||||
|
在这个文本插件的帮助下,SystemJS可以读取任何原始文件并将其内容作为字符串返回。
|
||||||
|
你需要使用它来导入语言翻译文件。
|
||||||
|
|
||||||
SystemJS doesn't ship with a raw text plugin but it's easy to add.
|
SystemJS doesn't ship with a raw text plugin but it's easy to add.
|
||||||
Create the following `systemjs-text-plugin.js` in the root folder:
|
Create the following `systemjs-text-plugin.js` in the root folder:
|
||||||
|
|
||||||
|
SystemJS没有自带原始文本插件,但是我们很容易添加它。
|
||||||
|
在根目录新建下面的`systemjs-text-plugin.js`文件:
|
||||||
|
|
||||||
+makeExample('cb-i18n/ts/systemjs-text-plugin.js', null, 'systemjs-text-plugin.js')(format='.')
|
+makeExample('cb-i18n/ts/systemjs-text-plugin.js', null, 'systemjs-text-plugin.js')(format='.')
|
||||||
:marked
|
:marked
|
||||||
### Create translation providers
|
### Create translation providers
|
||||||
|
|
||||||
|
### 新建翻译提供商
|
||||||
|
|
||||||
Three providers tell the JiT compiler how to translate the template texts for a particular language
|
Three providers tell the JiT compiler how to translate the template texts for a particular language
|
||||||
while compiling the application:
|
while compiling the application:
|
||||||
|
|
||||||
|
三种提供商帮助JiT编译在编译应用时,将模板文本翻译到某种语言:
|
||||||
|
|
||||||
* `TRANSLATIONS` is a string containing the content of the translation file.
|
* `TRANSLATIONS` is a string containing the content of the translation file.
|
||||||
|
|
||||||
|
* `TRANSLATIONS`是含有翻译文件内容的字符串。
|
||||||
|
|
||||||
* `TRANSLATIONS_FORMAT` is the format of the file: `xlf`, `xlif` or `xtb`
|
* `TRANSLATIONS_FORMAT` is the format of the file: `xlf`, `xlif` or `xtb`
|
||||||
|
|
||||||
|
* `TRANSLATIONS_FORMAT`是文件的格式: `xlf`、`xlif`或`xtb`。
|
||||||
|
|
||||||
* `LOCALE_ID` is the locale of the target language.
|
* `LOCALE_ID` is the locale of the target language.
|
||||||
|
|
||||||
|
* `LOCALE_ID`是目标语言的语言环境。
|
||||||
|
|
||||||
The `getTranslationProviders` function in the following `app/i18n-providers.ts`
|
The `getTranslationProviders` function in the following `app/i18n-providers.ts`
|
||||||
creates those providers based on the user's _locale_
|
creates those providers based on the user's _locale_
|
||||||
and the corresponding translation file:
|
and the corresponding translation file:
|
||||||
|
|
||||||
|
在下面的`app/i18n-providers.ts`文件的getTranslationProviders`函数中,根据用户的**语言环境**和对应的翻译文件构建这些提供商:
|
||||||
+makeExample('cb-i18n/ts/app/i18n-providers.ts', null, 'app/i18n-providers.ts')
|
+makeExample('cb-i18n/ts/app/i18n-providers.ts', null, 'app/i18n-providers.ts')
|
||||||
:marked
|
:marked
|
||||||
* It gets the locale from the global `document.locale` variable that was set in `index.html`.
|
* It gets the locale from the global `document.locale` variable that was set in `index.html`.
|
||||||
|
|
||||||
|
* 它从在`index.html`中设置的全局`document.locale`变量中获取语言环境。
|
||||||
|
|
||||||
* If there is no locale or the language is U.S. English (`en-US`), there is no need to translate.
|
* If there is no locale or the language is U.S. English (`en-US`), there is no need to translate.
|
||||||
The function returns an empty `noProviders` array as a `Promise`.
|
The function returns an empty `noProviders` array as a `Promise`.
|
||||||
It must return a `Promise` because this function could read a translation file asynchronously from the server.
|
It must return a `Promise` because this function could read a translation file asynchronously from the server.
|
||||||
|
|
||||||
|
* 如果没有语言环境或者语言是美国英语(`en-US`),则就无需翻译。
|
||||||
|
该函数以`Promise`的形式返回一个空的`noProviders`数组。
|
||||||
|
它必须要返回`Promise`,因为这个函数可能异步从服务器读取翻译文件。
|
||||||
|
|
||||||
* It creates a transaction filename from the locale according to the name and location convention
|
* It creates a transaction filename from the locale according to the name and location convention
|
||||||
[described earlier](#localization-folder).
|
[described earlier](#localization-folder).
|
||||||
|
|
||||||
|
* 根据[上面描述](#localization-folder)的名字和本土化的约定,它根据语言环境创建一个合约文件名。
|
||||||
|
|
||||||
* The `getTranslationsWithSystemJs` method reads the translation and returns the contents as a string.
|
* The `getTranslationsWithSystemJs` method reads the translation and returns the contents as a string.
|
||||||
Notice that it appends `!text` to the filename, telling SystemJS to use the [text plugin](#text-plugin).
|
Notice that it appends `!text` to the filename, telling SystemJS to use the [text plugin](#text-plugin).
|
||||||
|
|
||||||
|
* `getTranslationsWithSystemJs`方法读取翻译并以字符串的形式返回其内容。
|
||||||
|
注意它在文件名上附加`!text`,告诉SystemJS使用[文本插件](#text-plugin)。
|
||||||
|
|
||||||
* The callback composes a providers array with the three translation providers.
|
* The callback composes a providers array with the three translation providers.
|
||||||
|
|
||||||
|
* 回调函数使用这三种翻译提供商创建一个提供商数组。
|
||||||
|
|
||||||
* Finally, `getTranslationProviders` returns the entire effort as a promise.
|
* Finally, `getTranslationProviders` returns the entire effort as a promise.
|
||||||
|
|
||||||
|
* 最后,`getTranslationProviders`返回以承诺的形式返回全部流程的结果。
|
||||||
|
|
||||||
### Bootstrap the app with translation providers
|
### Bootstrap the app with translation providers
|
||||||
|
|
||||||
|
### 使用翻译提供商引导应用
|
||||||
|
|
||||||
The Angular `bootstrapModule` method has a second, _options_ parameter
|
The Angular `bootstrapModule` method has a second, _options_ parameter
|
||||||
that can influence the behavior of the compiler.
|
that can influence the behavior of the compiler.
|
||||||
|
|
||||||
|
Angular的`bootstrapModule`方法接受**可选的**第二参数,它可以影响编译器的行为。
|
||||||
|
|
||||||
You'll create an _options_ object with the translation providers from `getTranslationProviders`
|
You'll create an _options_ object with the translation providers from `getTranslationProviders`
|
||||||
and pass it to `bootstrapModule`.
|
and pass it to `bootstrapModule`.
|
||||||
Open the `app/main.ts` and modify the bootstrap code as follows:
|
Open the `app/main.ts` and modify the bootstrap code as follows:
|
||||||
|
|
||||||
|
从`getTranslationProviders`返回的翻译提供商创建_options_对象,并将其传给`bootstrapModule`。
|
||||||
|
打开`app/main.ts`并这样修改引导代码:
|
||||||
|
|
||||||
+makeExample('cb-i18n/ts/app/main.ts', null, 'app/main.ts')(format=".")
|
+makeExample('cb-i18n/ts/app/main.ts', null, 'app/main.ts')(format=".")
|
||||||
:marked
|
:marked
|
||||||
Notice that it waits for the `getTranslationProviders` promise to resolve before
|
Notice that it waits for the `getTranslationProviders` promise to resolve before
|
||||||
bootstrapping the app.
|
bootstrapping the app.
|
||||||
|
|
||||||
|
注意,它等待`getTranslationProviders`承诺的解析完成后,才引导应用。
|
||||||
|
|
||||||
The app is now _internationalized_ for English and French and there is a clear path for adding
|
The app is now _internationalized_ for English and French and there is a clear path for adding
|
||||||
more languages.
|
more languages.
|
||||||
|
|
||||||
|
现在,应用已经被国际化为英语版和法语版,而且我们有了清晰的添加更多语言的方法。
|
||||||
|
|
||||||
a#aot
|
a#aot
|
||||||
.l-main-section
|
.l-main-section
|
||||||
:marked
|
:marked
|
||||||
### _Internationalize_ with the AoT compiler
|
### _Internationalize_ with the AoT compiler
|
||||||
|
|
||||||
|
### 使用AoT编译器时的国际化
|
||||||
|
|
||||||
The JiT compiler translates the application into the target language while compiling dynamically in the browser.
|
The JiT compiler translates the application into the target language while compiling dynamically in the browser.
|
||||||
That's flexible but may not be fast enough for your users.
|
That's flexible but may not be fast enough for your users.
|
||||||
|
|
||||||
|
JiT编译器在浏览器中动态编译应用时,将其翻译到目标语言。
|
||||||
|
这样很灵活,但是对用户来讲,可能速度太慢。
|
||||||
|
|
||||||
The AoT (_Ahead-of-Time_) compiler is part of a build process that produces a small, fast, ready-to-run application package.
|
The AoT (_Ahead-of-Time_) compiler is part of a build process that produces a small, fast, ready-to-run application package.
|
||||||
When you internationalize with the AoT compiler, you pre-build a separate application package for each
|
When you internationalize with the AoT compiler, you pre-build a separate application package for each
|
||||||
language. Then in the host web page (`index.html`), you determine which language the user needs
|
language. Then in the host web page (`index.html`), you determine which language the user needs
|
||||||
and serve the appropriate application package.
|
and serve the appropriate application package.
|
||||||
|
|
||||||
|
AoT(预先)编译器是一种构建流程,出产尺寸小、速度快和可执行的应用程序包。
|
||||||
|
在使用Aot编译器的环境中国际化,你为每种语言预先构建一个单独的应用程序包。然后,在宿主网络页面(`index.html`)中,你再决定用户需要哪种语言,并选择合适的应用程序包。
|
||||||
|
|
||||||
This cookbook doesn't cover how to build multiple application packages and
|
This cookbook doesn't cover how to build multiple application packages and
|
||||||
serve them according to the user's language preference.
|
serve them according to the user's language preference.
|
||||||
It does explain the few steps necessary to tell the AoT to apply a translations file.
|
It does explain the few steps necessary to tell the AoT to apply a translations file.
|
||||||
|
|
||||||
|
本烹饪书不介绍如何构建多种应用程序包和如何根据用户的语言设置推送它们。
|
||||||
|
它介绍了一些必要的步骤,来告诉AoT采用用翻译文件。
|
||||||
|
|
||||||
Internationalization with the AoT compiler requires some setup specifically for AoT.
|
Internationalization with the AoT compiler requires some setup specifically for AoT.
|
||||||
Start with application project as shown [just before merging the translation file](#app-pre-translationStart)
|
Start with application project as shown [just before merging the translation file](#app-pre-translationStart)
|
||||||
and refer to the [AoT cookbook](aot-compiler.html) to make it _AoT-ready_.
|
and refer to the [AoT cookbook](aot-compiler.html) to make it _AoT-ready_.
|
||||||
|
|
||||||
|
使用AoT编译器时的国际化,需要一些针对AoT的设置。
|
||||||
|
以[合并翻译文件之前](#app-pre-translationStart)的应用项目开始,并参见[AoT烹饪书](aot-compiler.html),把它变成与AoT兼容的项目。
|
||||||
|
|
||||||
Next, issue an `ngc` compile command for each supported language (including English).
|
Next, issue an `ngc` compile command for each supported language (including English).
|
||||||
The result is a separate version of the application for each language.
|
The result is a separate version of the application for each language.
|
||||||
|
|
||||||
|
接下来,为每种支持的语言(包括英语)运行一次`ngc`编译命令。
|
||||||
|
结果是每种语言都有自己单独的应用版本。
|
||||||
|
|
||||||
Tell AoT how to translate by adding three options to the `ngc` command:
|
Tell AoT how to translate by adding three options to the `ngc` command:
|
||||||
|
|
||||||
|
通过添加下面三种选项到`ngc`命令来告诉AoT编译器如何翻译:
|
||||||
|
|
||||||
* `--i18nFile`: the path to the translation file
|
* `--i18nFile`: the path to the translation file
|
||||||
|
|
||||||
|
* `--i18nFile`: 翻译文件的路径
|
||||||
|
|
||||||
* `--locale`: the name of the locale
|
* `--locale`: the name of the locale
|
||||||
|
|
||||||
|
* `--locale`: 语言环境的名字
|
||||||
|
|
||||||
* `--i18nFormat`: the format of the localization file
|
* `--i18nFormat`: the format of the localization file
|
||||||
|
|
||||||
|
* `--i18nFormat`: 翻译文件的格式
|
||||||
|
|
||||||
For this sample, the French language command would be
|
For this sample, the French language command would be
|
||||||
|
|
||||||
|
本法语例子的命令为:
|
||||||
code-example(language="sh" class="code-shell").
|
code-example(language="sh" class="code-shell").
|
||||||
./node_modules/.bin/ngc --i18nFile=./locale/messages.fr.xlf --locale=fr --i18nFormat=xlf
|
./node_modules/.bin/ngc --i18nFile=./locale/messages.fr.xlf --locale=fr --i18nFormat=xlf
|
||||||
|
|
||||||
.l-sub-section
|
.l-sub-section
|
||||||
:marked
|
:marked
|
||||||
Windows users may have to quote the command:
|
Windows users may have to quote the command:
|
||||||
|
|
||||||
|
Windows用户可能需要双引号这个命令:
|
||||||
code-example(language="sh" class="code-shell").
|
code-example(language="sh" class="code-shell").
|
||||||
"./node_modules/.bin/ngc" --i18nFile=./locale/messages.fr.xlf --locale=fr --i18nFormat=xlf
|
"./node_modules/.bin/ngc" --i18nFile=./locale/messages.fr.xlf --locale=fr --i18nFormat=xlf
|
||||||
|
|
|
@ -4,61 +4,125 @@ block includes
|
||||||
:marked
|
:marked
|
||||||
# Documentation Change Log
|
# Documentation Change Log
|
||||||
|
|
||||||
|
# 文档变更日志
|
||||||
|
|
||||||
The Angular documentation is a living document with continuous improvements.
|
The Angular documentation is a living document with continuous improvements.
|
||||||
This log calls attention to recent significant changes.
|
This log calls attention to recent significant changes.
|
||||||
|
|
||||||
|
我们将持续不断的更新和改进Angular文档。本日志记录了近期最重要的变更。
|
||||||
|
|
||||||
## Sync with Angular v.2.1.0 (2016-10-12)
|
## Sync with Angular v.2.1.0 (2016-10-12)
|
||||||
Docs and code samples updated and tested with Angular v.2.1.0
|
|
||||||
|
## 与Angular v.2.1.0同步(2016-10-12)
|
||||||
|
Docs and code samples updated and tested with Angular v.2.1.0
|
||||||
|
|
||||||
|
使用Angular v.2.1.0更新和测试所有文档和代码例子。
|
||||||
|
|
||||||
## NEW "Ahead of Time (AoT) Compilation" cookbook (2016-10-11)
|
## NEW "Ahead of Time (AoT) Compilation" cookbook (2016-10-11)
|
||||||
|
|
||||||
|
## 添加了新的“预编译(AoT)"烹饪书(2016-10-11)
|
||||||
|
|
||||||
The NEW [Ahead of Time (AoT) Compilation](../cookbook/aot-compiler.html) cookbook
|
The NEW [Ahead of Time (AoT) Compilation](../cookbook/aot-compiler.html) cookbook
|
||||||
explains what AoT compilation is and why you'd want it.
|
explains what AoT compilation is and why you'd want it.
|
||||||
It demonstrates the basics with a QuickStart app
|
It demonstrates the basics with a QuickStart app
|
||||||
followed by the more advanced considerations of compiling and bundling the Tour of Heroes.
|
followed by the more advanced considerations of compiling and bundling the Tour of Heroes.
|
||||||
|
|
||||||
|
全新[预编译(AoT)](../cookbook/aot-compiler.html)烹饪书介绍了什么是AoT编译和为何你需要它。
|
||||||
|
它以**快速开始**应用程序开始讲解,接着介绍了编译和构建**英雄指南**的更高级的注意事项。
|
||||||
|
|
||||||
## Sync with Angular v.2.0.2 (2016-10-6)
|
## Sync with Angular v.2.0.2 (2016-10-6)
|
||||||
|
|
||||||
|
## 与Angular v.2.0.2同步 (2016-10-6)
|
||||||
|
|
||||||
Docs and code samples updated and tested with Angular v.2.0.2
|
Docs and code samples updated and tested with Angular v.2.0.2
|
||||||
|
|
||||||
|
使用Angular v.2.0.2更新和测试所有文档和代码例子。
|
||||||
|
|
||||||
## "Routing and Navigation" guide with the _Router Module_ (2016-10-5)
|
## "Routing and Navigation" guide with the _Router Module_ (2016-10-5)
|
||||||
|
|
||||||
|
## 在“路由和导航”向导中添加**路由模块** (2016-10-5)
|
||||||
|
|
||||||
The [Routing and Navigation](router.html) guide now locates route configuration
|
The [Routing and Navigation](router.html) guide now locates route configuration
|
||||||
in a _Routing Module_.
|
in a _Routing Module_.
|
||||||
The _Routing Module_ replaces the previous _routing object_ involving the `ModuleWithProviders`.
|
The _Routing Module_ replaces the previous _routing object_ involving the `ModuleWithProviders`.
|
||||||
|
|
||||||
|
[Routing and Navigation](router.html)现在在**路由模块**中设置路由配置。
|
||||||
|
**路由模块**替换之前的**路由对象**,使用了`ModuleWithProviders`。
|
||||||
|
|
||||||
|
[Routing and Navigation](router.html)
|
||||||
|
|
||||||
|
[路由与导航](router.html)
|
||||||
|
|
||||||
All guided samples with routing use the _Routing Module_ and prose content has been updated,
|
All guided samples with routing use the _Routing Module_ and prose content has been updated,
|
||||||
most conspicuously in the
|
most conspicuously in the
|
||||||
[NgModule](ngmodule.html) guide and [NgModule FAQ](../cookbook/ngmodule-faq.html) cookbook.
|
[NgModule](ngmodule.html) guide and [NgModule FAQ](../cookbook/ngmodule-faq.html) cookbook.
|
||||||
|
|
||||||
|
所有使用路由的例子都使用**路由模块**,相关内容也被更新。更新最多的是[Angular模块(NgModule)](ngmodule.html)章和[Angular模块常见问题](../cookbook/ngmodule-faq.html)烹饪书。
|
||||||
|
|
||||||
## New "Internationalization" Cookbook (2016-09-30)
|
## New "Internationalization" Cookbook (2016-09-30)
|
||||||
|
|
||||||
|
## 全新“国际化”烹饪书(2016-09-30)
|
||||||
|
|
||||||
Added a new [Internationalization (i18n)](../cookbook/i18n.html) cookbook that shows how
|
Added a new [Internationalization (i18n)](../cookbook/i18n.html) cookbook that shows how
|
||||||
to use Angular "i18n" facilities to translate template text into multiple languages.
|
to use Angular "i18n" facilities to translate template text into multiple languages.
|
||||||
|
|
||||||
|
添加了新的[国际化(i18n)](../cookbook/i18n.html)烹饪书,展示了如何使用Angular的“i18n”工具来讲模板文本翻译到多种语言。
|
||||||
|
|
||||||
## "angular-in-memory-web-api" package rename (2016-09-27)
|
## "angular-in-memory-web-api" package rename (2016-09-27)
|
||||||
|
|
||||||
|
## 重命名“angular-in-memory-web-api”包(2016-09-27)
|
||||||
|
|
||||||
Many samples use the `angular-in-memory-web-api` to simulate a remote server.
|
Many samples use the `angular-in-memory-web-api` to simulate a remote server.
|
||||||
This library is also useful to you during early development before you have a server to talk to.
|
This library is also useful to you during early development before you have a server to talk to.
|
||||||
|
|
||||||
|
许多例子使用了`angular-in-memory-web-api`来模拟远程服务器。
|
||||||
|
这个库在你拥有服务器之前的早期开发阶段也很有用。
|
||||||
|
|
||||||
The package name was changed from "angular2-in-memory-web-api" which is still frozen-in-time on npm.
|
The package name was changed from "angular2-in-memory-web-api" which is still frozen-in-time on npm.
|
||||||
The new "angular-in-memory-web-api" has new features.
|
The new "angular-in-memory-web-api" has new features.
|
||||||
<a href="https://github.com/angular/in-memory-web-api/blob/master/README.md" target="_blank">Read about them on github</a>.
|
<a href="https://github.com/angular/in-memory-web-api/blob/master/README.md" target="_blank">Read about them on github</a>.
|
||||||
|
|
||||||
|
这个包的名字从“angular2-in-memory-web-api”(仍然有效,但不再更新了)重新命名了。
|
||||||
|
新的“angular-in-memory-web-api”有新的功能。
|
||||||
|
<a href="https://github.com/angular/in-memory-web-api/blob/master/README.md" target="_blank">到github获得更多详情</a>.
|
||||||
|
|
||||||
## "Style Guide" with _NgModules_ (2016-09-27)
|
## "Style Guide" with _NgModules_ (2016-09-27)
|
||||||
|
|
||||||
|
## “风格指南”中添加了_NgModules_(2016-09-27)
|
||||||
|
|
||||||
[StyleGuide](style-guide.html) explains our recommended conventions for Angular modules (NgModule).
|
[StyleGuide](style-guide.html) explains our recommended conventions for Angular modules (NgModule).
|
||||||
|
|
||||||
|
[StyleGuide](style-guide.html)解释了我们为Angular模块(NgModule)而推荐的约定。
|
||||||
|
|
||||||
Barrels now are far less useful and have been removed from the style guide;
|
Barrels now are far less useful and have been removed from the style guide;
|
||||||
they remain valuable but are not a matter of Angular style.
|
they remain valuable but are not a matter of Angular style.
|
||||||
We also relaxed the rule that discouraged use of the `@Component.host` property.
|
We also relaxed the rule that discouraged use of the `@Component.host` property.
|
||||||
|
|
||||||
|
现在,封装桶不再那么重要,风格指南已经移除了它们。
|
||||||
|
它们仍然很有价值,但是它们与Angular风格无关。
|
||||||
|
我们同时对**不推荐使用`@Component.host`属性**的规则有所放宽。
|
||||||
|
|
||||||
## _moduleId: module.id_ everywhere (2016-09-25)
|
## _moduleId: module.id_ everywhere (2016-09-25)
|
||||||
|
|
||||||
|
## moduleId:到处添加module.id(2016-09-25)
|
||||||
|
|
||||||
Sample components that get their templates or styles with `templateUrl` or `styleUrls`
|
Sample components that get their templates or styles with `templateUrl` or `styleUrls`
|
||||||
have been converted to _module-relative_ URLs.
|
have been converted to _module-relative_ URLs.
|
||||||
We added the `moduleId: module.id` property-and-value to their `@Component` metadata.
|
We added the `moduleId: module.id` property-and-value to their `@Component` metadata.
|
||||||
|
|
||||||
|
在所有使用`templateUrl`或者`styleUrls`来获取模板或样式的例子组件都被转换为**相对模块**的URL。
|
||||||
|
我们添加了`moduleId: module.id`到它们的`@Component`元数据。
|
||||||
|
|
||||||
This change is a requirement for compilation with AoT compiler when the app loads
|
This change is a requirement for compilation with AoT compiler when the app loads
|
||||||
modules with SystemJS as the samples currently do.
|
modules with SystemJS as the samples currently do.
|
||||||
|
|
||||||
|
当应用像例子当前使用的方法一样 - 使用SystemJS加载模块时,本更新是AoT编译器的前提条件。
|
||||||
|
|
||||||
## "Lifecycle Hooks" guide simplified (2016-09-24)
|
## "Lifecycle Hooks" guide simplified (2016-09-24)
|
||||||
|
|
||||||
|
## 简化了“生命周期钩子”章(2016-09-24)
|
||||||
|
|
||||||
The [Lifecycle Hooks](lifecycle-hooks.html) guide is shorter, simpler, and
|
The [Lifecycle Hooks](lifecycle-hooks.html) guide is shorter, simpler, and
|
||||||
draws more attention to the order in which Angular calls the hooks.
|
draws more attention to the order in which Angular calls the hooks.
|
||||||
|
|
||||||
|
[生命周期钩子](lifecycle-hooks.html)章现在更加简短,并且对强调了Angular是以什么顺序来调用钩子方法的。
|
||||||
|
|
|
@ -3240,7 +3240,7 @@ h3#can-deactivate-guard <i>CanDeactivate</i>:处理未保存的更改
|
||||||
:marked
|
:marked
|
||||||
The `DialogService` (provided in the `AppModule` for app-wide use) does the asking.
|
The `DialogService` (provided in the `AppModule` for app-wide use) does the asking.
|
||||||
|
|
||||||
`DialogService`(为了在应用级使用,已经注入到了`AppComponent`)就可以做到这些。
|
`DialogService`(为了在应用级使用,已经注入到了`AppModule`)就可以做到这些。
|
||||||
|
|
||||||
It returns a [promise](http://exploringjs.com/es6/ch_promises.html) that
|
It returns a [promise](http://exploringjs.com/es6/ch_promises.html) that
|
||||||
*resolves* when the user eventually decides what to do: either
|
*resolves* when the user eventually decides what to do: either
|
||||||
|
@ -3293,7 +3293,7 @@ a#CanDeactivate
|
||||||
:marked
|
:marked
|
||||||
We also need to add the `Guard` to our main `AppRoutingModule` `providers` so the `Router` can inject it during the navigation process.
|
We also need to add the `Guard` to our main `AppRoutingModule` `providers` so the `Router` can inject it during the navigation process.
|
||||||
|
|
||||||
我们还要把这个`Guard`添加到主文件的`appRouterProviders`中去,以便`Router`可以在导航过程中注入它。
|
我们还要把这个`Guard`添加到`appRoutingModule`的`providers`中去,以便`Router`可以在导航过程中注入它。
|
||||||
|
|
||||||
+makeExample('app/app-routing.module.4.ts', '', '')
|
+makeExample('app/app-routing.module.4.ts', '', '')
|
||||||
|
|
||||||
|
@ -3327,7 +3327,7 @@ h3#resolve-guard <i>解析</i>: 提前获取组件数据
|
||||||
|
|
||||||
可以预先从服务器读取数据,这样在路由器被激活时,数据已经返回。同时,我们还需要处理数据返回失败和其它出错情况。这样,在`Crisis Center`中,对处理导航到一个无返回数据的`id`有帮助。
|
可以预先从服务器读取数据,这样在路由器被激活时,数据已经返回。同时,我们还需要处理数据返回失败和其它出错情况。这样,在`Crisis Center`中,对处理导航到一个无返回数据的`id`有帮助。
|
||||||
我们可以将用户发回只列出有效危机的`Crisis List`。
|
我们可以将用户发回只列出有效危机的`Crisis List`。
|
||||||
直到成功获取所有必须的数据或一些行为已经发生,应用需要延迟渲染路由组件。
|
我们需要延迟渲染路由组件,来等待所有必要的数据都成功获取或做一些其他操作。
|
||||||
|
|
||||||
We need the `Resolve` guard.
|
We need the `Resolve` guard.
|
||||||
|
|
||||||
|
@ -3575,9 +3575,8 @@ a#fragment
|
||||||
Our `AdminModule` is the area of our application that would be scoped to a small set of users, so we'll take advantage
|
Our `AdminModule` is the area of our application that would be scoped to a small set of users, so we'll take advantage
|
||||||
of asynchronous routing and only load the `Admin` feature area when requested.
|
of asynchronous routing and only load the `Admin` feature area when requested.
|
||||||
|
|
||||||
我们接下来在当前的项目中添加这些特征。现在已经有一系列模块将应用组织为三大块:`AppModule`, `HeroesModule` 和 `CrisisCenterModule`。
|
我们接下来在当前的项目中添加这些特征。现在已经有一系列模块将应用组织为四大块:`AppModule`, `HeroesModule`, `AdminModule` 和 `CrisisCenterModule`。
|
||||||
`CrisisCenterModule`是功能最多,尺寸最大的模块,我们将使用异步路由,实现只有在被请求时才加载`Crisis Center`特征区。
|
`AdminModule`在我们的应用中只被小部分用户访问, 所以我们利用异步路由来实现只有在请求时才加载`Admin`特性区域。
|
||||||
|
|
||||||
:marked
|
:marked
|
||||||
### Lazy-Loading route configuration
|
### Lazy-Loading route configuration
|
||||||
|
|
||||||
|
@ -3637,7 +3636,7 @@ a#fragment
|
||||||
to break our `AdminModule` into a completely separate module. In our `app.module.ts`, we'll remove our `AdminModule` from the
|
to break our `AdminModule` into a completely separate module. In our `app.module.ts`, we'll remove our `AdminModule` from the
|
||||||
`imports` array since we'll be loading it on-demand an we'll remove the imported `AdminModule`.
|
`imports` array since we'll be loading it on-demand an we'll remove the imported `AdminModule`.
|
||||||
|
|
||||||
我们构建了特性区,更新了路由配置来实现惰性加载,现在该做最后一步:将`CrisisCenterModule`分离到一个彻底独立的模块。因为现在按需加载`CrisisCenterModule`,所以在`app.module.ts`中,从`imports`数组中删除它。
|
我们构建了特性区,更新了路由配置来实现惰性加载,现在该做最后一步:将`AdminModule`分离到一个彻底独立的模块。因为现在按需加载`AdminModule`,所以在`app.module.ts`中,从`imports`数组中删除它。
|
||||||
|
|
||||||
+makeExcerpt('app/app.module.ts (async admin module)', '')
|
+makeExcerpt('app/app.module.ts (async admin module)', '')
|
||||||
|
|
||||||
|
|
|
@ -1,7 +1,7 @@
|
||||||
.about-cn-translation
|
.about-cn-translation
|
||||||
:marked
|
:marked
|
||||||
## 关于译者
|
## 关于译者
|
||||||
本文档有两位译者,它们是多年的好友。这次利用业余时间联手翻译,就是因为看好 Angular 2 的前景,希望帮助大家在这项技术上能跟国外同步前进。
|
本文档有两位译者,他们是多年的好友。这次利用业余时间联手翻译,就是因为看好 Angular 2 的前景,希望帮助大家在这项技术上能跟国外同步前进。
|
||||||
|
|
||||||
### 汪志成(雪狼)
|
### 汪志成(雪狼)
|
||||||
《AngularJS深度剖析与最佳实践》的作者之一,ThoughtWorks 高级咨询师,现任 GDE( Google 开发者专家)。崇尚“简单、专业、分享”。它从1998年开始做商业软件开发,拥有超过18年的从业经验,至今仍热衷于编程。
|
《AngularJS深度剖析与最佳实践》的作者之一,ThoughtWorks 高级咨询师,现任 GDE( Google 开发者专家)。崇尚“简单、专业、分享”。它从1998年开始做商业软件开发,拥有超过18年的从业经验,至今仍热衷于编程。
|
||||||
|
@ -17,7 +17,7 @@
|
||||||
|
|
||||||
本中文网站能够达到现在的质量,首先要感谢 Google 公司 Angular 产品开发部门的项目经理 Naomi Black 的鼎力支持。她不但邀请我们加入了 Angular 项目组,还让我们与各位文档作者之间建立了直接的沟通渠道。这种沟通渠道非常宝贵,让我们得以准确理解所涉及到的各个技术细节,并减轻了保持同步更新时的额外工作量。
|
本中文网站能够达到现在的质量,首先要感谢 Google 公司 Angular 产品开发部门的项目经理 Naomi Black 的鼎力支持。她不但邀请我们加入了 Angular 项目组,还让我们与各位文档作者之间建立了直接的沟通渠道。这种沟通渠道非常宝贵,让我们得以准确理解所涉及到的各个技术细节,并减轻了保持同步更新时的额外工作量。
|
||||||
|
|
||||||
本网站能够及时推出,要感谢 Google 开发技术推广部大中华区的负责人栾跃、以及负责和我们进行项目协调沟通的 Google 开发技术推广部中国团队的项目经理程路。它们的专业性和高效率让我们得以心无旁骛的完成翻译工作。也是在它们的大力帮助下,本网站才能最终作为官方中文版推出。
|
本网站能够及时推出,要感谢 Google 开发技术推广部大中华区的负责人栾跃、以及负责和我们进行项目协调沟通的 Google 开发技术推广部中国团队的项目经理程路。他们的专业性和高效率让我们得以心无旁骛的完成翻译工作。也是在他们的大力帮助下,本网站才能最终作为官方中文版推出。
|
||||||
|
|
||||||
最后,要特别感谢我们各自的家人。同步、高质量的翻译是个耗时耗力的工作,如果没有她们的支持,此工作将无法完成。
|
最后,要特别感谢我们各自的家人。同步、高质量的翻译是个耗时耗力的工作,如果没有她们的支持,此工作将无法完成。
|
||||||
|
|
||||||
|
|
Loading…
Reference in New Issue