1

我最近一直在使用 Angular 2 并且对它比较陌生。

鉴于即将发布的版本,我决定升级到最新版本,这是第一个 Angular 4 候选版本。我尝试使用建议的命令,即:

npm install @angular/{common,compiler,compiler-cli,core,forms,http,platform-browser,platform-browser-dynamic,platform-server,router,animations}@next --save

该命令失败,我从其他帖子中了解到该语法在我不熟悉的 bash 中可用。

我将路径设置为我的项目文件夹,然后尝试使用以下方法单独安装每个包:

npm install @angular/common@next --save 

对于每个包。这似乎部分有效,但给出了许多依赖警告。

现在的结果是我不能再使用ng serve并且我认为我的设置至少可以说有些损坏。有人可以建议一种使用节点卸载 angular(全局和本地)的方法,这样我就可以从头开始安装 angular 4 rc1 和最新的 angular cli。

4

2 回答 2

0

我花了一些时间让它工作(据我所知)。

这是你必须做的(相反,这是我做了几次测试并且它有效)。按顺序执行这些步骤。

像往常一样使用 Angular cli 创建您的项目。

像往常一样,进入该项目目录。

删除节点模块。

单独安装 webpack(以确保您获得最新版本 ^2)。

npm install webpack

用下面的文件替换你的 package.json 文件,然后运行 ​​npm install。

运行服务

项目启动。

请注意,在运行 ng serve 时,您会看到 20 多个这样的错误。他们似乎没有阻止项目运行,我在浏览器控制台中没有看到任何错误。

[default] /Users/tcoz/web-dev-projects/angular4/node_modules/@angular/platform-browser/typings/src/dom/dom_renderer.d.ts:58:41 
    Initializers are not allowed in ambient contexts.

另一件事:我没有全局安装 TS。不确定这是否重要,但可能。确保您运行的是最新版本 (^2.2.1)。

package.json(请注意,许多东西都更新了,不仅仅是角度,一些依赖消息令人困惑,直到我刚刚安装了 webpack 2):

{
  "name": "angular4",
  "version": "0.0.0",
  "license": "MIT",
  "angular-cli": {},
  "scripts": {
    "start": "ng serve",
    "lint": "tslint \"src/**/*.ts\"",
    "test": "ng test",
    "pree2e": "webdriver-manager update",
    "e2e": "protractor"
  },
  "private": true,
  "dependencies": {
    "@angular/compiler": "4.0.0-rc.1",
    "@angular/core": "4.0.0-rc.1",
    "@angular/common": "4.0.0-rc.1",
    "@angular/forms": "4.0.0-rc.1",
    "@angular/http": "4.0.0-rc.1",
    "@angular/platform-browser": "4.0.0-rc.1",
    "@angular/platform-browser-dynamic": "4.0.0-rc.1",
    "@angular/router": "4.0.0-rc.1",
    "core-js": "^2.4.1",
    "rxjs": "^5.0.1",
    "ts-helpers": "^1.1.1",
    "zone.js": "^0.7.2"
  },
  "devDependencies": {
    "@angular/compiler-cli": "4.0.0-rc.1",
    "@types/jasmine": "2.5.38",
    "@types/node": "^6.0.42",
    "angular-cli": "1.0.0-beta.21",
    "codelyzer": "3.0.0-beta.0",
    "jasmine-core": "2.5.2",
    "jasmine-spec-reporter": "2.5.0",
    "karma": "1.2.0",
    "karma-chrome-launcher": "^2.0.0",
    "karma-cli": "^1.0.1",
    "karma-jasmine": "^1.0.2",
    "karma-remap-istanbul": "^0.2.1",
    "protractor": "4.0.9",
    "ts-node": "1.2.1",
    "tslint": "^4.0.0",
    "typescript": "^2.2.1",
    "webdriver-manager": "10.2.5"
  }
}
于 2017-02-28T13:47:20.117 回答
0

在 package.json 中,我用当前的新版本(4.0.0-rc.3)替换了角度组件的版本号(2.4.9),并将@angular/router 指定为 4.0.0-rc.3 . 除了一些剑道组件的警告外,构建进展顺利。尽管有警告,kendo 组件仍按预期运行。

于 2017-03-10T22:26:47.933 回答