准备从 AngularJS 升级
Setup for upgrading from AngularJS
注意:本指南仅仅适用于从 AngularJS 升级和注重性能的升级。 本指南中提到的升级指南使用的是已弃用的快速上手 Github 仓库,它是在 Angular CLI 推出之前创建的。
Audience: Use this guide only in the context of Upgrading from AngularJS or Upgrading for Performance. Those Upgrade guides refer to this Setup guide for information about using the deprecated QuickStart GitHub repository, which was created prior to the current Angular CLI.
对于所有其它场景,请参阅建立本地开发环境中的步骤。
For all other scenarios, see the current instructions in Setting up the Local Environment and Workspace.
本指南讲的是如何在你自己的机器上进行本地化开发。 利用 github 上的《快速上手》种子在你的电脑上搭建一个新项目是很快很容易的。
This guide describes how to develop locally on your own machine. Setting up a new project on your machine is quick and easy with the QuickStart seed on github.
前提条件:确保你已经安装好了 Node.js® 和 npm。
Prerequisite: Make sure you have Node.js® and npm installed.
克隆
Clone
运行下列命令来执行克隆并启动步骤。
Perform the clone-to-launch steps with these terminal commands.
git clone https://github.com/angular/quickstart.git quickstart
cd quickstart
npm install
npm start
在Bash for Windows中 npm start
可能会失败,因为到 2017-04 为止它还不支持访问网络上的服务器。
npm start
fails in Bash for Windows in versions earlier than the Creator's Update (April 2017).
下载
Download
下载《快速上手》种子 并解压到你的项目目录中。然后执行下面的命令完成剩余步骤。
Download the QuickStart seed and unzip it into your project folder. Then perform the remaining steps with these terminal commands.
cd quickstart
npm install
npm start
在Bash for Windows中 npm start
可能会失败,因为到 2017-01 为止它还不支持访问网络上的服务器。
npm start
fails in Bash for Windows in versions earlier than the Creator's Update (April 2017).
删除非必需文件(可选)
Delete non-essential files (optional)
你可以快速删除一些涉及到测试和维护快速开始版本库的 非必需 文件 (包括所有 git 相关的文件如 .git
文件夹和 .gitignore
!)。
You can quickly delete the non-essential files that concern testing and QuickStart repository maintenance (including all git-related artifacts such as the .git
folder and .gitignore
!).
请只在开始时执行此删除操作,以防你自己的测试和 git 文件被意外删除!
Do this only in the beginning to avoid accidentally deleting your own tests and git setup!
在项目目录下打开一个终端窗口,并根据你的操作系统执行以下命令:
Open a terminal window in the project folder and enter the following commands for your environment:
OS/X (bash)
xargs rm -rf < non-essential-files.osx.txt
rm src/app/*.spec*.ts
rm non-essential-files.osx.txt
Windows
for /f %i in (non-essential-files.txt) do del %i /F /S /Q
rd .git /s /q
rd e2e /s /q
《快速上手》种子库里都有什么?
What's in the QuickStart seed?
《快速上手》种子 提供了一个基本的《快速上手》游乐场应用,以及进行本地开发的其它必要文件。 所以,你电脑里的项目目录中有更多文件,其中的大部分你都会在稍后学到。
The QuickStart seed provides a basic QuickStart playground application and other files necessary for local development. Consequently, there are many files in the project folder on your machine, most of which you can learn about later.
Reminder: The "QuickStart seed" example was created prior to the Angular CLI, so there are some differences between what is described here and an Angular CLI application.
注意/src
目录中以下三个 TypeScript (.ts
) 文件:
Focus on the following three TypeScript (.ts
) files in the /src
folder.
src
app
app.component.ts
app.module.ts
main.ts
所有指南和烹饪书都至少有这几个核心文件。每个文件都有独特的用途,并且随着应用的成长各自独立演变。
All guides and cookbooks have at least these core files. Each file has a distinct purpose and evolves independently as the application grows.
src/
目录之外的文件为构建、部署和测试 app 相关的文件,他们只包括配置文件和外部依赖。
Files outside src/
concern building, deploying, and testing your app. They include configuration files and external dependencies.
src/
目录下的文件才“属于”你的 app。 除非明确指出,否则教程中添加的 TypeScript,HTML 和 CSS 文件都在 src/
目录下, 大多数在 src/app
目录中。
Files inside src/
"belong" to your app. Add new Typescript, HTML and CSS files inside the src/
directory, most of them inside src/app
, unless told to do otherwise.
src/
目录文件详情如下:
The following are all in src/
文件 File | 用途 Purpose |
---|---|
| 定义与《快速上手》游乐场同样的 Defines the same |
| 定义 Defines |
| 使即时 (JIT) 编译器用编译应用并且在浏览器中启动并运行应用。 对于大多数项目的开发,这都是合理的选择。而且它是在像 Stackblitz 这样的在线编程环境中运行例子的唯一选择。 你将在本文档中学习其它编译和开发选择。 Compiles the application with the JIT compiler and bootstraps the application's main module ( |
附录:用 IE 进行本地化开发
Appendix: Develop locally with IE
如果你使用 ng serve
进行本地化 Angular 开发,就会自动在浏览器和本地开发服务器之间建立一个 websocket
连接,这样,在代码发生变化时,浏览器就会自动刷新。
If you develop Angular locally with ng serve
, a websocket
connection is set up automatically between browser and local dev server, so when your code changes, the browser can automatically refresh.
在 Windows 上,默认情况下,每个应用最多只能有 6 个 websocket 连接,参阅 MSDN 上的 WebSocket 设置。 所以,当 IE 刷新时(手动刷新或由 ng serve
自动刷新),websocket 可能无法正常关闭。当 websocket 连接数超过上限时,就会抛出一个 SecurityError
异常。这种错误不会影响 Angular 应用,你可以重启 IE 来清除此异常或在 Windows 注册表中加大这个上限。
In Windows, by default, one application can only have 6 websocket connections, MSDN WebSocket Settings. So when IE is refreshed (manually or automatically by ng serve
), sometimes the websocket does not close properly. When websocket connections exceed the limitations, a SecurityError
will be thrown. This error will not affect the Angular application, you can just restart IE to clear this error, or modify the windows registry to update the limitations.
附录:使用 fakeAsync()/waitForAsync()
进行测试
Appendix: Test using fakeAsync()/waitForAsync()
如果你使用 fakeAsync()/async()
辅助函数来运行单元测试(详情参阅测试指南),就要在测试的准备文件中导入 zone.js/testing
。
If you use the fakeAsync()/waitForAsync()
helper functions to run unit tests (for details, read the Testing guide), you need to import zone.js/testing
in your test setup file.
如果你是用 Angular/CLI
创建的项目,那么它已经在 src/test.ts
中导入过了。
If you create project with Angular/CLI
, it is already imported in src/test.ts
.
在以前版本的 Angular
中,下列文件曾被导入或添加到 html 文件中:
And in the earlier versions of Angular
, the following files were imported or added in your html file:
import 'zone.js/plugins/long-stack-trace-zone';
import 'zone.js/plugins/proxy';
import 'zone.js/plugins/sync-test';
import 'zone.js/plugins/jasmine-patch';
import 'zone.js/plugins/async-test';
import 'zone.js/plugins/fake-async-test';
你仍然可以分别导入这些文件,不过导入顺序很重要,你必须在 sync-test
、async-test
、fake-async-test
和 jasmine-patch
之前导入 proxy
。还要注意在 jasmine-patch
之前导入 sync-test
。所以,建议你只导入 zone-testing
而不要分别加载那些文件。
You can still load those files separately, but the order is important, you must import proxy
before sync-test
, async-test
, fake-async-test
and jasmine-patch
. And you also need to import sync-test
before jasmine-patch
, so it is recommended to just import zone-testing
instead of loading those separated files.