状況によっては、ここにある事前コンパイルのクックブックを実行し始めたばかりですが、エラーが直接関連しているとは思いません: https://angular.io/guide/aot-compiler
私は Visual Studio 2015 を使用しており、Angular 2 プロジェクトを新しくリリースされた 2.4 に更新し、すべてが正常にビルドされました。ただし、tsconfig.json ファイルを変更"lib": [ "es2015", "dom" ]
して、compilerOptions に追加しました。ファイルは次のようになります。
{
"compilerOptions": {
"target": "es5",
"module": "commonjs",
"moduleResolution": "node",
"sourceMap": true,
"emitDecoratorMetadata": true,
"experimentalDecorators": true,
"lib": [ "es2015", "dom" ],
"removeComments": false,
"noImplicitAny": true,
"outDir": "dist",
"suppressImplicitAnyIndexErrors": true
},
"compileOnSave": true
}
この変更の後、再ビルドしたところ、次のビルド エラーが発生しました。
ビルド: 識別子 'PropertyKey' が重複しています。
私はいくつかの調査を行い"@types/core-js": "^0.9.34"
、package.json ファイルから削除することにしました。これにより、そのエラーは解決されたようですが、現在、次の新しいエラーのインスタンスがいくつかあります。
ビルド: 'Set' という名前が見つかりません
ビルド: 名前 'Promise' が見つかりません
ビルド: 'Map' という名前が見つかりません
これが私の完全なpackage.jsonファイルです:
{
"name": "angular2-quickstart",
"version": "1.0.0",
"scripts": {
"start": "tsc && concurrently \"tsc -w\" \"lite-server\" ",
"docker-build": "docker build -t ng2-quickstart .",
"docker": "npm run docker-build && docker run -it --rm -p 3000:3000 -p 3001:3001 ng2-quickstart",
"pree2e": "npm run webdriver:update",
"e2e": "tsc && concurrently \"http-server -s\" \"protractor protractor.config.js\" --kill-others --success first",
"lint": "tslint ./app/**/*.ts -t verbose",
"lite": "lite-server",
"postinstall": "typings install",
"test": "tsc && concurrently \"tsc -w\" \"karma start karma.conf.js\"",
"test-once": "tsc && karma start karma.conf.js --single-run",
"tsc": "tsc",
"tsc:w": "tsc -w",
"typings": "typings",
"webdriver:update": "webdriver-manager update"
},
"license": "MIT",
"dependencies": {
"@angular/common": "~2.4.0",
"@angular/compiler": "~2.4.0",
"@angular/compiler-cli": "^2.4.1",
"@angular/core": "~2.4.0",
"@angular/forms": "~2.4.0",
"@angular/http": "~2.4.0",
"@angular/platform-browser": "~2.4.0",
"@angular/platform-browser-dynamic": "~2.4.0",
"@angular/platform-server": "^2.4.1",
"@angular/router": "~3.4.0",
"@angular/upgrade": "~2.4.0",
"angular-in-memory-web-api": "~0.1.16",
"bootstrap": "^3.3.7",
"core-js": "^2.4.1",
"reflect-metadata": "^0.1.8",
"rxjs": "5.0.1",
"systemjs": "0.19.39",
"zone.js": "^0.7.4"
},
"devDependencies": {
"@types/node": "^6.0.45",
"concurrently": "^3.0.0",
"lite-server": "^2.2.2",
"typescript": "^2.0.3"
},
"repository": {}
}
新しいリリースの最新情報を入手するために、サンプルの package.json ファイルの依存関係部分をほぼコピーしました: https://angular.io/guide/quickstart
そのリンクは、私が見つけることができる唯一のものであるため、JavaScript バージョン用ですが、実際には TypeScript 2.1.4 を使用しています。そのため、このファイルの一部が古くなっている可能性があります。どの部分を具体的に決定するかはわかりません。