2017-12-19 46 views
0

今日、Angular 4.4.4から5.1.1へのアップグレードを開始しました。私は角度にも依存する他の多くのパッケージをアップグレードしなければなりませんでした。私は少しの文脈で間違いを覚えてどこから始めるのか分からない。他の誰かがこれを見て、問題が何かを知っていますか?TypeError:未定義のプロパティ 'members'を読み取ることができません

$ ng serve --aot=false 
** NG Live Development Server is listening on localhost:4200, open your browser on http://localhost:4200/ ** 
Date: 2017-12-19T15:26:36.137Z 
Hash: bf0b773d5dfafdd9133b 
Time: 16934ms 
chunk {inline} inline.bundle.js (inline) 5.79 kB [entry] [rendered] 
chunk {main} main.bundle.js (main) 2.93 kB [initial] [rendered] 
chunk {polyfills} polyfills.bundle.js (polyfills) 636 bytes [initial] [rendered] 
chunk {scripts} scripts.bundle.js (scripts) 307 kB [initial] [rendered] 
chunk {styles} styles.bundle.js (styles) 4.03 MB [initial] [rendered] 
chunk {vendor} vendor.bundle.js (vendor) 855 kB [initial] [rendered] 

ERROR in TypeError: Cannot read property 'members' of undefined 
    at AotSummaryResolver.resolveSummary (C:\source\app\node_modules\@angular\compiler\bundles\compiler.umd.js:32638:56) 
    at CompileMetadataResolver._loadSummary (C:\source\app\node_modules\@angular\compiler\bundles\compiler.umd.js:14825:66) 
    at CompileMetadataResolver._getEntryComponentMetadata (C:\source\app\node_modules\@angular\compiler\bundles\compiler.umd.js:15857:66) 
    at C:\source\app\node_modules\@angular\compiler\bundles\compiler.umd.js:15323:55 
    at Array.map (<anonymous>) 
    at CompileMetadataResolver.getNgModuleMetadata (C:\source\app\node_modules\@angular\compiler\bundles\compiler.umd.js:15323:18) 
    at CompileMetadataResolver.getNgModuleSummary (C:\source\app\node_modules\@angular\compiler\bundles\compiler.umd.js:15157:52) 
    at C:\source\app\node_modules\@angular\compiler\bundles\compiler.umd.js:15245:72 
    at Array.forEach (<anonymous>) 
    at CompileMetadataResolver.getNgModuleMetadata (C:\source\app\node_modules\@angular\compiler\bundles\compiler.umd.js:15230:49) 
    at visitLazyRoute (C:\source\app\node_modules\@angular\compiler\bundles\compiler.umd.js:31061:104) 
    at AotCompiler.listLazyRoutes (C:\source\app\node_modules\@angular\compiler\bundles\compiler.umd.js:31029:20) 
    at AngularCompilerProgram.listLazyRoutes (C:\source\app\node_modules\@angular\compiler-cli\src\transformers\program.js:156:30) 
    at Function.NgTools_InternalApi_NG_2.listLazyRoutes (C:\source\app\node_modules\@angular\compiler-cli\src\ngtools_api.js:44:36) 
    at AngularCompilerPlugin._getLazyRoutesFromNgtools (C:\source\app\node_modules\@ngtools\webpack\src\angular_compiler_plugin.js:248:66) 
    at Promise.resolve.then.then (C:\source\app\node_modules\@ngtools\webpack\src\angular_compiler_plugin.js:562:50) 

webpack: Failed to compile. 

私はそれが奇妙な私が仕えるコマンドに=偽--aotてきたとき、それはAotSummaryResolverで始まることを見つけます。

{ 
    "name": "test", 
    "version": "0.0.0", 
    "license": "MIT", 
    "scripts": { 
    "ng": "ng", 
    "start": "ng serve --aot=false", 
    "build": "ng build", 
    "test": "ng test", 
    "lint": "ng lint", 
    "e2e": "ng e2e" 
    }, 
    "private": true, 
    "dependencies": { 
    "@agm/core": "^1.0.0-beta.2", 
    "@angular-devkit/schematics": "^0.0.42", 
    "@angular/animations": "5.1.1", 
    "@angular/cdk": "5.0.1", 
    "@angular/common": "5.1.1", 
    "@angular/compiler": "5.1.1", 
    "@angular/core": "5.1.1", 
    "@angular/forms": "5.1.1", 
    "@angular/http": "5.1.1", 
    "@angular/platform-browser": "5.1.1", 
    "@angular/platform-browser-dynamic": "5.1.1", 
    "@angular/platform-server": "5.1.1", 
    "@angular/router": "5.1.1", 
    "@auth0/angular-jwt": "^1.0.0-beta.9", 
    "@ng-bootstrap/ng-bootstrap": "^1.0.0-beta.8", 
    "@ng-idle/core": "^2.0.0-beta.13", 
    "@ngrx/core": "^1.2.0", 
    "@ngrx/effects": "^4.1.1", 
    "@ngrx/entity": "^4.1.1", 
    "@ngrx/store": "^4.1.1", 
    "@ngrx/store-devtools": "^4.1.1", 
    "@schematics/angular": "^0.1.11", 
    "@schematics/schematics": "^0.0.11", 
    "angular2-counto": "^1.2.3", 
    "bootstrap": "4.0.0-beta.2", 
    "core-js": "2.4.1", 
    "d3": "^4.11.0", 
    "echarts": "^3.6.0", 
    "echarts-gl": "^1.0.0-alpha.5", 
    "font-awesome": "^4.7.0", 
    "global": "^4.3.2", 
    "intl": "^1.2.5", 
    "jquery": "^3.2.1", 
    "moment": "^2.19.4", 
    "ng2-dnd": "^5.0.2", 
    "popper.js": "^1.11.0", 
    "roboto-fontface": "^0.7.0", 
    "rxjs": "^5.5.2", 
    "toastr": "^2.1.2", 
    "ts-action": "^3.2.2", 
    "typings": "^2.1.1", 
    "uuid": "^3.1.0", 
    "web-animations-js": "^2.2.5", 
    "yarn": "^0.24.5", 
    "zone.js": "0.8.4" 
    }, 
    "devDependencies": { 
    "@angular/cli": "1.6.1", 
    "@angular/compiler-cli": "5.1.1", 
    "@types/d3": "^4.11.0", 
    "@types/echarts": "^0.0.6", 
    "@types/hammerjs": "^2.0.34", 
    "@types/jasmine": "2.5.38", 
    "@types/jquery": "^2.0.45", 
    "@types/node": "^7.0.23", 
    "@types/toastr": "^2.1.33", 
    "@types/uuid": "^3.4.0", 
    "codelyzer": "^4.0.2", 
    "jasmine-core": "~2.5.2", 
    "jasmine-spec-reporter": "~3.2.0", 
    "json-server": "^0.12.0", 
    "jsonwebtoken": "^7.4.1", 
    "karma": "~1.4.1", 
    "karma-chrome-launcher": "~2.1.1", 
    "karma-cli": "~1.0.1", 
    "karma-coverage-istanbul-reporter": "^0.2.0", 
    "karma-jasmine": "~1.1.0", 
    "karma-jasmine-html-reporter": "^0.2.2", 
    "protractor": "~5.1.0", 
    "ts-node": "~2.0.0", 
    "tslint": "^5.8.0", 
    "typemoq": "^1.7.0", 
    "typescript": "2.4.2" 
    } 
} 

マイ角度-cliのバージョンは1.6.1です:

は、ここに私のpackage.jsonです。

エラーが角度のソースコードで、ここで発生するようです: https://github.com/angular/angular/blob/b3eb1db6dd57a0820cfc94af5460ceb3fea20610/packages/compiler/src/aot/summary_resolver.ts#L68

編集

以前、私はそれが間違っていたNG-ブートストラップに関連していたと思いました。

私は次のようにcompiler.umd.jsにライン15207でコンソールログを置くことによって、それのためにいくつかのコンテキストが見つかりました:

が生じ
if (meta.entryComponents) { 
    console.log(meta); 
    entryComponents.push.apply(entryComponents, flattenAndDedupeArray(meta.entryComponents) 
       .map(function (type) { return /** @type {?} */ ((_this._getEntryComponentMetadata(type))); })); 
} 

... 
entryComponents: [ undefined ], 
... 

私はとのモジュールを持っていましたentryComponents: [MdProgressSpinner]MdProgressSpinnerはインポートされませんでした。私はそれを削除したときにエラーが消えた...そして次のものが来た:

+0

あなたはそれがアップグレード前に働いていたことを確認する前に、あなたのコードをテストしましたか? –

+0

これは、サードパーティの角度別パッケージがたくさんあります。これはバージョンの変更(変更の変更)であるため、これらすべてのパッケージが新しいバージョンをサポートしていることを確認する必要があります。 (ng-boostrap、ng-idle、ngrx、schematics、angular2-countoなど) –

+0

@MikeTungはい、アップグレードの直前に実行しました。 – bygrace

答えて

0

これはあなたのアプリケーションモジュールで発生する理由の1つは、ビルドプロセスがインポートを見つけることができないエントリコンポーネントがありますfor(以下の例では、インポート行をコメントアウトしてコンポーネントを残すと、このエラーが発生します)。 enter image description here

enter image description here

関連する問題