开发指南-TypeScript配置 初译完毕
This commit is contained in:
parent
101a16560b
commit
55cd18616b
|
@ -3,59 +3,104 @@ include ../_util-fns
|
||||||
:marked
|
:marked
|
||||||
TypeScript is a primary language for Angular application development.
|
TypeScript is a primary language for Angular application development.
|
||||||
|
|
||||||
|
TypeScript是Angular应用开发中使用的主语言。
|
||||||
|
|
||||||
TypeScript is a dialect of JavaScript with design-time support for type-safety and tooling.
|
TypeScript is a dialect of JavaScript with design-time support for type-safety and tooling.
|
||||||
|
|
||||||
|
TypeScript是JavaScript的“方言”之一,为类型安全和工具化而做了设计期支持。
|
||||||
|
|
||||||
Browsers can't execute TypeScript directly. It has to be "transpiled" into JavaScript with the *tsc* compiler
|
Browsers can't execute TypeScript directly. It has to be "transpiled" into JavaScript with the *tsc* compiler
|
||||||
and that effort requires some configuration.
|
and that effort requires some configuration.
|
||||||
|
|
||||||
|
浏览器不能直接执行TypeScript。它得先用*tsc*编译器转译(transpile)成JavaScript,而且这项工作需要进行一定的配置。
|
||||||
|
|
||||||
This chapter covers some aspects of TypeScript configuration and the TypeScript environment
|
This chapter covers some aspects of TypeScript configuration and the TypeScript environment
|
||||||
that are important to Angular developers.
|
that are important to Angular developers.
|
||||||
|
|
||||||
|
本章会覆盖TypeScript配置与环境的某些方面,这些对Angular开发者是很重要的。
|
||||||
|
|
||||||
* [tsconfig.json](#tsconfig) - TypeScript compiler configuration.
|
* [tsconfig.json](#tsconfig) - TypeScript compiler configuration.
|
||||||
|
|
||||||
|
* [tsconfig.json](#tsconfig) - TypeScript编译器配置。
|
||||||
|
|
||||||
* [typings](#typings) - TypesScript declaration files.
|
* [typings](#typings) - TypesScript declaration files.
|
||||||
|
|
||||||
|
* [typings](#typings) - TypesScript类型声明文件。
|
||||||
|
|
||||||
a(id="tsconfig")
|
a(id="tsconfig")
|
||||||
.l-main-section
|
.l-main-section
|
||||||
:marked
|
:marked
|
||||||
## *tsconfig.json*
|
## *tsconfig.json*
|
||||||
We typically add a TypeScript configuration file (`tsconfig.json`) to our project to
|
We typically add a TypeScript configuration file (`tsconfig.json`) to our project to
|
||||||
guide the compiler as it generates JavaScript files.
|
guide the compiler as it generates JavaScript files.
|
||||||
|
|
||||||
|
我们通常会往项目中加入一个TypeScript配置文件(`tsconfig.json`),来指导编译器如何生成JavaScript文件。
|
||||||
.l-sub-section
|
.l-sub-section
|
||||||
:marked
|
:marked
|
||||||
Get details about `tsconfig.json` from the official
|
Get details about `tsconfig.json` from the official
|
||||||
[TypeScript wiki](https://github.com/Microsoft/TypeScript/wiki/tsconfig.json).
|
[TypeScript wiki](https://github.com/Microsoft/TypeScript/wiki/tsconfig.json).
|
||||||
|
|
||||||
|
要了解关于`tsconfig.json`的详情,请参阅官方提供的
|
||||||
|
[TypeScript wiki](https://github.com/Microsoft/TypeScript/wiki/tsconfig.json)。
|
||||||
:marked
|
:marked
|
||||||
We created the following `tsconfig.json` for the [QuickStart](../quickstart.html):
|
We created the following `tsconfig.json` for the [QuickStart](../quickstart.html):
|
||||||
|
|
||||||
|
我们在[快速起步](../quickstart.html)中创建过如下的`tsconfig.json`:
|
||||||
|
|
||||||
+makeJson('quickstart/ts/tsconfig.1.json', null, 'tsconfig.json')(format=".")
|
+makeJson('quickstart/ts/tsconfig.1.json', null, 'tsconfig.json')(format=".")
|
||||||
:marked
|
:marked
|
||||||
The options and flags in this file are essential for Angular 2 applications.
|
The options and flags in this file are essential for Angular 2 applications.
|
||||||
|
|
||||||
|
该文件中的选项和标志是写Angular 2应用程序的基础。
|
||||||
|
|
||||||
<a id="noImplicitAny"></a>
|
<a id="noImplicitAny"></a>
|
||||||
### *noImplicitAny* and *suppressImplicitAnyIndexErrors*
|
### *noImplicitAny* and *suppressImplicitAnyIndexErrors*
|
||||||
|
### *noImplicitAny*与*suppressImplicitAnyIndexErrors*
|
||||||
|
|
||||||
TypeScript developers disagree about whether the `noImplicitAny` flag should be `true` or `false`.
|
TypeScript developers disagree about whether the `noImplicitAny` flag should be `true` or `false`.
|
||||||
There is no correct answer and we can change the flag later.
|
There is no correct answer and we can change the flag later.
|
||||||
But our choice now can make a difference in larger projects so it merits discussion.
|
But our choice now can make a difference in larger projects so it merits discussion.
|
||||||
|
|
||||||
|
TypeScript开发者们在`noImplicitAny`标志应该是`true`还是`false`上存在分歧。
|
||||||
|
这没有标准答案,我们以后还可以修改这个标志。
|
||||||
|
但是我们的选择会在大项目中产生显著差异,所以它值得讨论一番。
|
||||||
|
|
||||||
When the `noImplicitAny` flag is `false` (the default),
|
When the `noImplicitAny` flag is `false` (the default),
|
||||||
the compiler silently defaults the type of a variable to `any` if it cannot infer
|
the compiler silently defaults the type of a variable to `any` if it cannot infer
|
||||||
the type based on how the variable is used. That's what we mean by *implicit `any`*.
|
the type based on how the variable is used. That's what we mean by *implicit `any`*.
|
||||||
|
|
||||||
|
当`noImplicitAny`标志是`false`(默认值)时,
|
||||||
|
如果编译器无法根据变量的用途推断出变量的类型,它就会悄悄的把变量类型默认为`any`。
|
||||||
|
这就是*隐式`any`*的含义。
|
||||||
|
|
||||||
We initialized the `noImplicitAny` flag to `false` in the QuickStart
|
We initialized the `noImplicitAny` flag to `false` in the QuickStart
|
||||||
to make learning TypeScript development easier.
|
to make learning TypeScript development easier.
|
||||||
|
|
||||||
|
我们在“快速起步”中把`noImplicitAny`标志初始化为`false`,是为了让学习TypeScript开发更简单点儿。
|
||||||
|
|
||||||
When the `noImplicitAny` flag is `true` and the TypeScript compiler cannot infer
|
When the `noImplicitAny` flag is `true` and the TypeScript compiler cannot infer
|
||||||
the type, it still generates the JavaScript files. But it also **reports an error**.
|
the type, it still generates the JavaScript files. But it also **reports an error**.
|
||||||
Many seasoned developers prefer this stricter setting because type checking catches more
|
Many seasoned developers prefer this stricter setting because type checking catches more
|
||||||
unintentional errors at compile time.
|
unintentional errors at compile time.
|
||||||
|
|
||||||
|
当`noImplicitAny`标志是`true`并且TypeScript编译器无法推断出类型时,它仍然会生成JavaScript文件。
|
||||||
|
但是它也会**报告一个错误**。
|
||||||
|
很多饱经沧桑的程序员更喜欢这种严格的设置,因为类型检查能在编译期间捕获更多意外错误。
|
||||||
|
|
||||||
We can set a variable's type to `any` even when the `noImplicitAny` flag is `true`.
|
We can set a variable's type to `any` even when the `noImplicitAny` flag is `true`.
|
||||||
We do so when that seems like the best choice for the situation,
|
We do so when that seems like the best choice for the situation,
|
||||||
deliberately and explicitly, after giving the matter some thought.
|
deliberately and explicitly, after giving the matter some thought.
|
||||||
|
|
||||||
|
即使`noImplicitAny`标志设置为`true`,我们也仍然能把变量的类型指定为`any`。
|
||||||
|
在经过了审慎而明确的评估之后,如果某种情况下它看起来确实是最佳选择,那我们就这么做。
|
||||||
|
|
||||||
If we set the `noImplicitAny` flag to `true`, we may get *implicit index errors* as well.
|
If we set the `noImplicitAny` flag to `true`, we may get *implicit index errors* as well.
|
||||||
Most developers feel that *this particular error* is more annoying than helpful.
|
Most developers feel that *this particular error* is more annoying than helpful.
|
||||||
We can suppress them with the following additional flag.
|
We can suppress them with the following additional flag.
|
||||||
|
|
||||||
|
如果我们把`noImplicitAny`标志设置为了`true`,我们可能会得到*隐式索引错*。
|
||||||
|
大多数程序员可能觉得*这种错误*是个是个烦恼而不是助力。
|
||||||
|
我们可以使用下列附加标志来禁止它们。
|
||||||
code-example(format=".").
|
code-example(format=".").
|
||||||
"suppressImplicitAnyIndexErrors":true
|
"suppressImplicitAnyIndexErrors":true
|
||||||
|
|
||||||
|
@ -64,62 +109,111 @@ a(id="typings")
|
||||||
.l-main-section
|
.l-main-section
|
||||||
:marked
|
:marked
|
||||||
## TypeScript Typings
|
## TypeScript Typings
|
||||||
|
## TypeScript类型定义(typings)
|
||||||
Many JavaScript libraries such as jQuery, the Jasmine testing library, and Angular itself,
|
Many JavaScript libraries such as jQuery, the Jasmine testing library, and Angular itself,
|
||||||
extend the JavaScript environment with features and syntax
|
extend the JavaScript environment with features and syntax
|
||||||
that the TypeScript compiler doesn't recognize natively.
|
that the TypeScript compiler doesn't recognize natively.
|
||||||
When the compiler doesn't recognize something, it throws an error.
|
When the compiler doesn't recognize something, it throws an error.
|
||||||
|
|
||||||
|
很多JavaScript库,比如jQuery、Jasmine测试库和Angular自己,会通过新的特性和语法来扩展JavaScript环境。
|
||||||
|
而TypeScript编译器并不能原生的识别它们。
|
||||||
|
当编译器不能识别时,它就会抛出一个错误。
|
||||||
|
|
||||||
We use [TypeScript type definition files](http://www.typescriptlang.org/Handbook#writing-dts-files)
|
We use [TypeScript type definition files](http://www.typescriptlang.org/Handbook#writing-dts-files)
|
||||||
— *d.ts files* — to tell the compiler about the libraries we load.
|
— *d.ts files* — to tell the compiler about the libraries we load.
|
||||||
|
|
||||||
|
我们可以使用[TypeScript类型定义文件](http://www.typescriptlang.org/Handbook#writing-dts-files)
|
||||||
|
—— *.d.ts文件* ——来告诉编译器,这些我们要加载的库的类型定义。
|
||||||
|
|
||||||
TypeScript-aware editors leverage these same definition files to display type information about library features.
|
TypeScript-aware editors leverage these same definition files to display type information about library features.
|
||||||
|
|
||||||
|
TypeScript敏感的编辑器借助这些定义文件来显示这些库中各个特性的类型定义。
|
||||||
|
|
||||||
Many libraries include their definition files in their npm packages where both the TypeScript compiler and editors
|
Many libraries include their definition files in their npm packages where both the TypeScript compiler and editors
|
||||||
can find them. Angular is one such library.
|
can find them. Angular is one such library.
|
||||||
Peek into the `node_modules/@angular/core/` folder of any Angular application to see several `...d.ts` files that describe parts of Angular.
|
Peek into the `node_modules/@angular/core/` folder of any Angular application to see several `...d.ts` files that describe parts of Angular.
|
||||||
|
|
||||||
|
很多库在自己的npm包中都包含了它们的类型定义文件,TypeScript编译器和编辑器都能找到它们。Angular库也是这样的。
|
||||||
|
进到任何Angular应用程序的`node_modules/@angular/core/`目录下,就能看到几个`...d.ts`文件,它们描述了Angular的各个部分。
|
||||||
|
|
||||||
**We need do nothing to get *typings* files for library packages which include *d.ts* files — as all Angular packages do.**
|
**We need do nothing to get *typings* files for library packages which include *d.ts* files — as all Angular packages do.**
|
||||||
|
|
||||||
|
**我们不需要为那些包含了*d.ts*文件的库获取*类型定义*文件 —— Angular的所有包都是如此。**
|
||||||
|
|
||||||
### Installable typings files
|
### Installable typings files
|
||||||
|
### 安装类型定义文件
|
||||||
Sadly, many libraries — jQuery, Jasmine, and Lodash among them — do *not* include `d.ts` files in their npm packages.
|
Sadly, many libraries — jQuery, Jasmine, and Lodash among them — do *not* include `d.ts` files in their npm packages.
|
||||||
Fortunately, either their authors or community contributors have created separate *d.ts* files for these libraries and
|
Fortunately, either their authors or community contributors have created separate *d.ts* files for these libraries and
|
||||||
published them in well-known locations.
|
published them in well-known locations.
|
||||||
The *typings* tool can find and fetch these files for us.
|
The *typings* tool can find and fetch these files for us.
|
||||||
|
|
||||||
|
遗憾的是,很多库 —— jQuery、Jasmine和Lodash等库 —— 都*没有*在它们自己的npm包中包含`d.ts`文件。
|
||||||
|
幸运的是,它们的作者或社区中的贡献者已经为这些库创建了独立的*d.ts*文件,并且把它们发布到了一个众所周知的位置。
|
||||||
|
有一个叫*typings*的工具可以为我们找到并获取这些文件。
|
||||||
|
|
||||||
We installed the [typings](https://github.com/typings/typings/blob/master/README.md) tool
|
We installed the [typings](https://github.com/typings/typings/blob/master/README.md) tool
|
||||||
with npm (it's listed among the *devDependencies* in the `package.json`) and added an npm script
|
with npm (it's listed among the *devDependencies* in the `package.json`) and added an npm script
|
||||||
to run that tool automatically after *npm* installation completes.
|
to run that tool automatically after *npm* installation completes.
|
||||||
|
|
||||||
|
我们已经用npm安装了这个[typings](https://github.com/typings/typings/blob/master/README.md)工具(它被列在了`package.json`的*devDependencies*中)
|
||||||
|
并添加了一个npm脚本,以便在所有*npm*包安装完之后运行那个工具。
|
||||||
|
|
||||||
+makeJson('quickstart/ts/package.1.json', {paths: 'scripts.postinstall'}, 'package.json (postinstall)')(format=".")
|
+makeJson('quickstart/ts/package.1.json', {paths: 'scripts.postinstall'}, 'package.json (postinstall)')(format=".")
|
||||||
:marked
|
:marked
|
||||||
This *typings* tool command installs the *d.ts* files that we identify in a `typings.json` file into the **typings** folder.
|
This *typings* tool command installs the *d.ts* files that we identify in a `typings.json` file into the **typings** folder.
|
||||||
We created a `typings.json` file in the [QuickStart](../quickstart.html):
|
We created a `typings.json` file in the [QuickStart](../quickstart.html):
|
||||||
|
|
||||||
|
这个*typings*命令行工具会把我们在`typings.json`文件中指定的那些*d.ts*文件安装进**typings**目录。
|
||||||
|
我们在[“快速起步”](../quickstart.html)中创建过这样一个`typings.json`文件:
|
||||||
|
|
||||||
+makeJson('quickstart/ts/typings.1.json', null, 'typings.json')(format=".")
|
+makeJson('quickstart/ts/typings.1.json', null, 'typings.json')(format=".")
|
||||||
:marked
|
:marked
|
||||||
We identified three *typings* file in the QuickStart, the *d.ts* files for
|
We identified three *typings* file in the QuickStart, the *d.ts* files for
|
||||||
|
|
||||||
|
我们在“快速起步”中指定过三个*类型定义*文件,这些*d.ts*文件是:
|
||||||
|
|
||||||
* [core-js](https://github.com/zloirock/core-js/blob/master/README.md)
|
* [core-js](https://github.com/zloirock/core-js/blob/master/README.md)
|
||||||
that brings ES2015/ES6 capabilities to our ES5 browsers
|
that brings ES2015/ES6 capabilities to our ES5 browsers
|
||||||
|
|
||||||
|
* [core-js](https://github.com/zloirock/core-js/blob/master/README.md)是为ES5浏览器添加ES2015/ES6特性的类型定义
|
||||||
|
|
||||||
* [jasmine](http://jasmine.github.io/) typings for the Jasmine test framework
|
* [jasmine](http://jasmine.github.io/) typings for the Jasmine test framework
|
||||||
|
|
||||||
|
* [jasmine](http://jasmine.github.io/)是Jasmine测试框架的类型定义
|
||||||
|
|
||||||
* [node](https://github.com/DefinitelyTyped/DefinitelyTyped/blob/master/node/node.d.ts) for code that references objects in the nodejs environment;
|
* [node](https://github.com/DefinitelyTyped/DefinitelyTyped/blob/master/node/node.d.ts) for code that references objects in the nodejs environment;
|
||||||
see the [webpack](./webpack.html) chapter for an example.
|
see the [webpack](./webpack.html) chapter for an example.
|
||||||
|
|
||||||
|
* [node](https://github.com/DefinitelyTyped/DefinitelyTyped/blob/master/node/node.d.ts)是为了在nodejs环境中引用对象的代码提供的类型定义。
|
||||||
|
在[webpack](./webpack.html)一章可以看到例子。
|
||||||
|
|
||||||
QuickStart itself doesn't require these typings but many of the documentation samples do.
|
QuickStart itself doesn't require these typings but many of the documentation samples do.
|
||||||
Most of us would be disappointed if we couldn't code against
|
Most of us would be disappointed if we couldn't code against
|
||||||
typical ES2015 features or support testing right out-of-the-box.
|
typical ES2015 features or support testing right out-of-the-box.
|
||||||
|
|
||||||
|
“快速起步”本身不需要这些类型定义,但是文档中的很多例子都需要。
|
||||||
|
如果没有写针对典型ES2015特性的代码或者写支持外部测试的代码,那我们多半儿会失望 —— 类型定义就没用了。
|
||||||
|
|
||||||
We can also run the *typings* tool ourselves.
|
We can also run the *typings* tool ourselves.
|
||||||
The following command (re)installs the typings files, as is sometimes necessary when the `postInstall` hook fails to do so.
|
The following command (re)installs the typings files, as is sometimes necessary when the `postInstall` hook fails to do so.
|
||||||
|
|
||||||
|
我们也可以自己运行*typings*工具。
|
||||||
|
如果npm的`postInstall`钩子执行失败了,也可以用下列命令来安装(或重装)这些类型定义文件。
|
||||||
|
|
||||||
code-example(format="").
|
code-example(format="").
|
||||||
npm run typings install
|
npm run typings install
|
||||||
:marked
|
:marked
|
||||||
This command lists the installed typings files:
|
This command lists the installed typings files:
|
||||||
|
|
||||||
|
该命令会列出已经安装的类型定义文件:
|
||||||
|
|
||||||
code-example(format="").
|
code-example(format="").
|
||||||
npm run typings list
|
npm run typings list
|
||||||
:marked
|
:marked
|
||||||
The following command installs or updates the typings file for the Jasmine test library from the *DefinitelyTyped* repository
|
The following command installs or updates the typings file for the Jasmine test library from the *DefinitelyTyped* repository
|
||||||
and updates the `typings.config` so we that we get it automatically the next time we install typings.
|
and updates the `typings.config` so we that we get it automatically the next time we install typings.
|
||||||
|
|
||||||
|
下列命令会从*DefinitelyTyped*仓库中为Jasmine测试库安装类型定义文件,并更新`typings.config`文件,以便当我们下次安装类型定义文件时会自动获取它。
|
||||||
code-example(format="").
|
code-example(format="").
|
||||||
npm run typings -- install dt~jasmine --save --global
|
npm run typings -- install dt~jasmine --save --global
|
||||||
.l-sub-section
|
.l-sub-section
|
||||||
|
@ -127,5 +221,10 @@ code-example(format="").
|
||||||
The [–– option](https://docs.npmjs.com/cli/run-script) is important;
|
The [–– option](https://docs.npmjs.com/cli/run-script) is important;
|
||||||
it tells npm to pass all arguments to the right of `--` to the *typings* command.
|
it tells npm to pass all arguments to the right of `--` to the *typings* command.
|
||||||
|
|
||||||
|
这个[––选项](https://docs.npmjs.com/cli/run-script)是很重要的,
|
||||||
|
它告诉npm要把`--`右侧的所有参数都传给*typings*命令。
|
||||||
|
|
||||||
Learn about the features of the *typings* tool at its [site on github](https://github.com/typings/typings/blob/master/README.md).
|
Learn about the features of the *typings* tool at its [site on github](https://github.com/typings/typings/blob/master/README.md).
|
||||||
|
|
||||||
|
要学习关于*typings*工具的更多特性,请到[它在github上的网站](https://github.com/typings/typings/blob/master/README.md)。
|
||||||
|
|
||||||
|
|
Loading…
Reference in New Issue