在 Angular 5 应用程序中找不到 'Fm' 的 Ngmodule 元数据
No Ngmodule metadata found for 'Fm' in Angular 5 application
关于这个问题的 SO 问题很少,但是 none 对我不起作用,因此发布了这个问题。
ng serve 工作正常但是当我 "ng build --prod" 并将应用程序部署到 cloud foundry 时显示此错误。
我已经尝试过针对同一问题提供的类似答案,但没有成功
.angular-cli.json 文件
{
"$schema": "./node_modules/@angular/cli/lib/config/schema.json",
"project": {
"name": "skf-dashboard"
},
"apps": [
{
"root": "src",
"outDir": "dist",
"assets": [
"assets",
"keycloak.json",
"favicon.ico",
"Staticfile.txt"
],
"index": "index.html",
"main": "main.ts",
"polyfills": "polyfills.ts",
"test": "test.ts",
"tsconfig": "tsconfig.app.json",
"testTsconfig": "tsconfig.spec.json",
"prefix": "app",
"styles": [
"../node_modules/font-awesome/scss/font-awesome.scss",
"../node_modules/angular-bootstrap-md/scss/bootstrap/bootstrap.scss",
"../node_modules/angular-bootstrap-md/scss/mdb-free.scss",
"./styles.scss"
],
"scripts": [
"../node_modules/jquery/dist/jquery.min.js",
"../node_modules/chart.js/dist/Chart.js",
"../node_modules/hammerjs/hammer.min.js",
"../src/assets/js/jquery.tempgauge.js",
"../node_modules/keycloak-js/dist/keycloak.min.js",
"../node_modules/bootstrap/dist/js/bootstrap.min.js"
],
"environmentSource": "environments/environment.ts",
"environments": {
"dev": "environments/environment.ts",
"prod": "environments/environment.prod.ts",
"mindsphere": "environments/environment.mindsphere.ts"
}
}
],
"e2e": {
"protractor": {
"config": "./protractor.conf.js"
}
},
"lint": [
{
"project": "src/tsconfig.app.json",
"exclude": "**/node_modules/**"
},
{
"project": "src/tsconfig.spec.json",
"exclude": "**/node_modules/**"
},
{
"project": "e2e/tsconfig.e2e.json",
"exclude": "**/node_modules/**"
}
],
"test": {
"karma": {
"config": "./karma.conf.js"
}
},
"defaults": {
"styleExt": "scss",
"component": {}
}
}
package.json 文件
{
"name": "skf-dashboard",
"version": "0.0.0",
"license": "PSL",
"scripts": {
"ng": "ng",
"start": "ng serve",
"build": "ng build",
"prod": "ng build --prod",
"oee-prod": "ng build --prod --base-href /oee/",
"oee-mindsphere": "ng build --prod --environment=mindsphere",
"test": "ng test",
"lint": "ng lint",
"e2e": "ng e2e"
},
"private": true,
"dependencies": {
"@angular-generic-table/column-settings": "^4.14.0",
"@angular-generic-table/core": "^4.14.0",
"@angular/animations": "5.2.11",
"@angular/common": "5.2.0",
"@angular/compiler": "5.2.0",
"@angular/core": "5.2.0",
"@angular/forms": "5.2.0",
"@angular/http": "5.2.0",
"@angular/platform-browser": "5.2.0",
"@angular/platform-browser-dynamic": "5.2.0",
"@angular/router": "5.2.0",
"@ngx-formly/bootstrap": "3.0.0",
"@ngx-formly/core": "3.0.0",
"@swimlane/ngx-datatable": "^11.3.2",
"@types/file-saver": "^2.0.0",
"angular-bootstrap-md": "^6.0.1",
"angular-gridster2": "^5.3.1",
"angular2-highcharts": "^0.5.5",
"bootstrap": "^4.1.1",
"chart.js": "2.5.0",
"core-js": "^2.4.1",
"file-saver": "^2.0.0",
"font-awesome": "4.7",
"hammerjs": "2.0.8",
"jquery": "^3.3.1",
"keycloak-js": "^3.4.3",
"ng2-dragula": "^1.5.0",
"ng2-pdf-viewer": "^5.2.3",
"ngx-daterangepicker-material": "^2.0.2",
"ngx-gauge": "^1.0.0-beta.5",
"ngx-toastr": "^8.7.3",
"rxjs": "5.5.2",
"sockjs-client": "^1.1.4",
"stompjs": "^2.3.3",
"tether": "^1.4.4",
"zone.js": "^0.8.19"
},
"devDependencies": {
"@angular/cli": "1.7.4",
"@angular/compiler-cli": "5.2.0",
"@angular/language-service": "5.2.0",
"@types/jasmine": "~2.8.3",
"@types/jasminewd2": "~2.0.2",
"@types/node": "~6.0.60",
"codelyzer": "^4.0.1",
"jasmine-core": "~2.8.0",
"jasmine-spec-reporter": "~4.2.1",
"karma": "~2.0.0",
"karma-chrome-launcher": "~2.2.0",
"karma-coverage-istanbul-reporter": "^1.2.1",
"karma-jasmine": "~1.1.0",
"karma-jasmine-html-reporter": "^0.2.2",
"protractor": "~5.1.2",
"ts-node": "~4.1.0",
"tslint": "~5.9.1",
"typescript": "~2.5.3"
}
}
index.html 文件
<!doctype html>
<html lang="en">
<head>
<meta charset="utf-8">
<title>OEE Dashboard</title>
<base href="/oee">
<meta name="viewport" content="width=device-width, initial-scale=1">
<link rel="icon" type="image/x-icon" href="favicon.ico">
<link rel="stylesheet" href="https://maxcdn.bootstrapcdn.com/bootstrap/4.0.0/css/bootstrap.min.css" integrity="sha384-Gn5384xqQ1aoWXA+058RXPxPg6fy4IWvTNh0E263XmFcJlSAwiGgFAW/dAiS6JXm"
crossorigin="anonymous">
<script src="https://static.eu1.mindsphere.io/osbar/v4/js/main.min.js"></script>
</head>
<body class="blue-grey lighten-5">
<div id="_mdspcontent">
<app-root></app-root>
</div>
<script src="https://code.jquery.com/jquery-3.2.1.slim.min.js" integrity="sha384-KJ3o2DKtIkvYIK3UENzmM7KCkRr/rE9/Qpg6aAZGJwFDMVNA/GpGFF93hXpG5KkN"
crossorigin="anonymous"></script>
<script src="https://cdnjs.cloudflare.com/ajax/libs/popper.js/1.12.9/umd/popper.min.js" integrity="sha384-ApNbgh9B+Y1QKtv3Rn7W3mgPxhU9K/ScQsAP7hUibX39j7fakFPskvXusvfa0b4Q"
crossorigin="anonymous"></script>
<script src="https://maxcdn.bootstrapcdn.com/bootstrap/4.0.0/js/bootstrap.min.js" integrity="sha384-JZR6Spejh4U02d8jOt6vLEHfe/JQGiRRSQQxSfFWpi1MquVdAyjUar5+76PVCmYl"
crossorigin="anonymous"></script>
</body>
</html>
main.ts 文件
import { enableProdMode } from '@angular/core';
import { platformBrowserDynamic } from '@angular/platform-browser-dynamic';
import { AppModule } from './app/app.module';
import { environment } from './environments/environment';
import { KeycloakService } from './app/services/keycloak.service';
if (environment.production) {
enableProdMode();
}
configureAndRunApplication ();
function configureAndRunApplication () {
let keycloakService : any = new KeycloakService;
if (!environment.is_mindsphere) {
console.log(keycloakService.keycloakStatus());
KeycloakService.init().then( e => {
if (keycloakService.hasRealmRole("oee_admin")){
fetch('assets/config/config.json').then(resp => resp.json()).then(systemConfig => {
window['system_config'] = systemConfig;
platformBrowserDynamic().bootstrapModule(AppModule);
});
} else {
keycloakService.logout();
}
}).catch(e => window.location.reload());
} else {
fetch('assets/config/config.json').then(resp => resp.json()).then(systemConfig => {
window['system_config'] = systemConfig;
platformBrowserDynamic().bootstrapModule(AppModule);
console.log(keycloakService.keycloakStatus());
});
}
}
当我部署和访问 url 它给了我 "No Ngmodule metadata found for 'Fm'"
如有任何帮助,我们将不胜感激。
我能够解决这个问题,这个问题似乎与编译有关。
当我在构建命令中选择性地添加 --aot 标志到 false 时,这个错误消失了。
最初,ng build --prod
(不适合我)
然后添加 ng build --aot=false --prod
关于这个问题的 SO 问题很少,但是 none 对我不起作用,因此发布了这个问题。 ng serve 工作正常但是当我 "ng build --prod" 并将应用程序部署到 cloud foundry 时显示此错误。
我已经尝试过针对同一问题提供的类似答案,但没有成功
.angular-cli.json 文件
{
"$schema": "./node_modules/@angular/cli/lib/config/schema.json",
"project": {
"name": "skf-dashboard"
},
"apps": [
{
"root": "src",
"outDir": "dist",
"assets": [
"assets",
"keycloak.json",
"favicon.ico",
"Staticfile.txt"
],
"index": "index.html",
"main": "main.ts",
"polyfills": "polyfills.ts",
"test": "test.ts",
"tsconfig": "tsconfig.app.json",
"testTsconfig": "tsconfig.spec.json",
"prefix": "app",
"styles": [
"../node_modules/font-awesome/scss/font-awesome.scss",
"../node_modules/angular-bootstrap-md/scss/bootstrap/bootstrap.scss",
"../node_modules/angular-bootstrap-md/scss/mdb-free.scss",
"./styles.scss"
],
"scripts": [
"../node_modules/jquery/dist/jquery.min.js",
"../node_modules/chart.js/dist/Chart.js",
"../node_modules/hammerjs/hammer.min.js",
"../src/assets/js/jquery.tempgauge.js",
"../node_modules/keycloak-js/dist/keycloak.min.js",
"../node_modules/bootstrap/dist/js/bootstrap.min.js"
],
"environmentSource": "environments/environment.ts",
"environments": {
"dev": "environments/environment.ts",
"prod": "environments/environment.prod.ts",
"mindsphere": "environments/environment.mindsphere.ts"
}
}
],
"e2e": {
"protractor": {
"config": "./protractor.conf.js"
}
},
"lint": [
{
"project": "src/tsconfig.app.json",
"exclude": "**/node_modules/**"
},
{
"project": "src/tsconfig.spec.json",
"exclude": "**/node_modules/**"
},
{
"project": "e2e/tsconfig.e2e.json",
"exclude": "**/node_modules/**"
}
],
"test": {
"karma": {
"config": "./karma.conf.js"
}
},
"defaults": {
"styleExt": "scss",
"component": {}
}
}
package.json 文件
{
"name": "skf-dashboard",
"version": "0.0.0",
"license": "PSL",
"scripts": {
"ng": "ng",
"start": "ng serve",
"build": "ng build",
"prod": "ng build --prod",
"oee-prod": "ng build --prod --base-href /oee/",
"oee-mindsphere": "ng build --prod --environment=mindsphere",
"test": "ng test",
"lint": "ng lint",
"e2e": "ng e2e"
},
"private": true,
"dependencies": {
"@angular-generic-table/column-settings": "^4.14.0",
"@angular-generic-table/core": "^4.14.0",
"@angular/animations": "5.2.11",
"@angular/common": "5.2.0",
"@angular/compiler": "5.2.0",
"@angular/core": "5.2.0",
"@angular/forms": "5.2.0",
"@angular/http": "5.2.0",
"@angular/platform-browser": "5.2.0",
"@angular/platform-browser-dynamic": "5.2.0",
"@angular/router": "5.2.0",
"@ngx-formly/bootstrap": "3.0.0",
"@ngx-formly/core": "3.0.0",
"@swimlane/ngx-datatable": "^11.3.2",
"@types/file-saver": "^2.0.0",
"angular-bootstrap-md": "^6.0.1",
"angular-gridster2": "^5.3.1",
"angular2-highcharts": "^0.5.5",
"bootstrap": "^4.1.1",
"chart.js": "2.5.0",
"core-js": "^2.4.1",
"file-saver": "^2.0.0",
"font-awesome": "4.7",
"hammerjs": "2.0.8",
"jquery": "^3.3.1",
"keycloak-js": "^3.4.3",
"ng2-dragula": "^1.5.0",
"ng2-pdf-viewer": "^5.2.3",
"ngx-daterangepicker-material": "^2.0.2",
"ngx-gauge": "^1.0.0-beta.5",
"ngx-toastr": "^8.7.3",
"rxjs": "5.5.2",
"sockjs-client": "^1.1.4",
"stompjs": "^2.3.3",
"tether": "^1.4.4",
"zone.js": "^0.8.19"
},
"devDependencies": {
"@angular/cli": "1.7.4",
"@angular/compiler-cli": "5.2.0",
"@angular/language-service": "5.2.0",
"@types/jasmine": "~2.8.3",
"@types/jasminewd2": "~2.0.2",
"@types/node": "~6.0.60",
"codelyzer": "^4.0.1",
"jasmine-core": "~2.8.0",
"jasmine-spec-reporter": "~4.2.1",
"karma": "~2.0.0",
"karma-chrome-launcher": "~2.2.0",
"karma-coverage-istanbul-reporter": "^1.2.1",
"karma-jasmine": "~1.1.0",
"karma-jasmine-html-reporter": "^0.2.2",
"protractor": "~5.1.2",
"ts-node": "~4.1.0",
"tslint": "~5.9.1",
"typescript": "~2.5.3"
}
}
index.html 文件
<!doctype html>
<html lang="en">
<head>
<meta charset="utf-8">
<title>OEE Dashboard</title>
<base href="/oee">
<meta name="viewport" content="width=device-width, initial-scale=1">
<link rel="icon" type="image/x-icon" href="favicon.ico">
<link rel="stylesheet" href="https://maxcdn.bootstrapcdn.com/bootstrap/4.0.0/css/bootstrap.min.css" integrity="sha384-Gn5384xqQ1aoWXA+058RXPxPg6fy4IWvTNh0E263XmFcJlSAwiGgFAW/dAiS6JXm"
crossorigin="anonymous">
<script src="https://static.eu1.mindsphere.io/osbar/v4/js/main.min.js"></script>
</head>
<body class="blue-grey lighten-5">
<div id="_mdspcontent">
<app-root></app-root>
</div>
<script src="https://code.jquery.com/jquery-3.2.1.slim.min.js" integrity="sha384-KJ3o2DKtIkvYIK3UENzmM7KCkRr/rE9/Qpg6aAZGJwFDMVNA/GpGFF93hXpG5KkN"
crossorigin="anonymous"></script>
<script src="https://cdnjs.cloudflare.com/ajax/libs/popper.js/1.12.9/umd/popper.min.js" integrity="sha384-ApNbgh9B+Y1QKtv3Rn7W3mgPxhU9K/ScQsAP7hUibX39j7fakFPskvXusvfa0b4Q"
crossorigin="anonymous"></script>
<script src="https://maxcdn.bootstrapcdn.com/bootstrap/4.0.0/js/bootstrap.min.js" integrity="sha384-JZR6Spejh4U02d8jOt6vLEHfe/JQGiRRSQQxSfFWpi1MquVdAyjUar5+76PVCmYl"
crossorigin="anonymous"></script>
</body>
</html>
main.ts 文件
import { enableProdMode } from '@angular/core';
import { platformBrowserDynamic } from '@angular/platform-browser-dynamic';
import { AppModule } from './app/app.module';
import { environment } from './environments/environment';
import { KeycloakService } from './app/services/keycloak.service';
if (environment.production) {
enableProdMode();
}
configureAndRunApplication ();
function configureAndRunApplication () {
let keycloakService : any = new KeycloakService;
if (!environment.is_mindsphere) {
console.log(keycloakService.keycloakStatus());
KeycloakService.init().then( e => {
if (keycloakService.hasRealmRole("oee_admin")){
fetch('assets/config/config.json').then(resp => resp.json()).then(systemConfig => {
window['system_config'] = systemConfig;
platformBrowserDynamic().bootstrapModule(AppModule);
});
} else {
keycloakService.logout();
}
}).catch(e => window.location.reload());
} else {
fetch('assets/config/config.json').then(resp => resp.json()).then(systemConfig => {
window['system_config'] = systemConfig;
platformBrowserDynamic().bootstrapModule(AppModule);
console.log(keycloakService.keycloakStatus());
});
}
}
当我部署和访问 url 它给了我 "No Ngmodule metadata found for 'Fm'"
如有任何帮助,我们将不胜感激。
我能够解决这个问题,这个问题似乎与编译有关。 当我在构建命令中选择性地添加 --aot 标志到 false 时,这个错误消失了。
最初,ng build --prod
(不适合我)
然后添加 ng build --aot=false --prod