![](/img/trans.png)
[英]Angular 9 - ngClass not working correctly on production environment
[英]Angular 9 Project is not working in production environment
我已经将我们的 Angular 混合项目从 8 迁移到 9。迁移进行得很顺利,ng build / ng serve 像以前一样运行良好。
真正的问题,我不知道如何开始工作,是在我构建了用于生产的应用程序之后(ng build --prod)。 项目登陆页面完全空白,没有JS错误,没有控制台警告。 看起来 AppModule 没有加载? 我们必须做的唯一更改与 main.aot.ts 文件相关,我们删除了该文件,因为它不再适用于 IVY 编译器。
您过去可能拥有的任何相关经验都会对我有所帮助,非常感谢!
main.ts 看起来像这样
import {enableProdMode, StaticProvider} from '@angular/core';
import { platformBrowserDynamic } from '@angular/platform-browser-dynamic';
import { AppModule } from './app/app.module';
import { environment } from './environments/environment';
import {downgradeModule} from "@angular/upgrade/static";
if (environment.production) {
enableProdMode();
}
declare var angular: any;
const bootstrapFn = (extraProviders: StaticProvider[]) => {
const platformRef = platformBrowserDynamic(extraProviders);
return platformRef.bootstrapModule(AppModule);
};
const downgradedModule = downgradeModule(bootstrapFn);
angular.bootstrap(document.getElementById('app-root'), ['angularJSModule', downgradedModule], { strictDi: true });
main.aot.ts (在 Angular9 中移除)
import {enableProdMode, StaticProvider} from '@angular/core';
import { platformBrowser } from '@angular/platform-browser';
import {AppModuleNgFactory} from './app/app.module.ngfactory';
import { environment } from './environments/environment';
import {downgradeModule} from "@angular/upgrade/static";
if (environment.production) {
enableProdMode();
}
declare var angular: any;
const bootstrapFn = (extraProviders: StaticProvider[]) => {
const platformRef = platformBrowser(extraProviders);
return platformRef.bootstrapModuleFactory(AppModuleNgFactory);
};
const downgradedModule = downgradeModule(bootstrapFn);
angular.bootstrap(document.getElementById('app-root'), ['angularJSModule', downgradedModule], { strictDi: true });
配置文件
{
"compileOnSave": true,
"compilerOptions": {
"baseUrl": "./",
"outDir": "./dist/out-tsc",
"sourceMap": true,
"declaration": false,
"downlevelIteration": true,
"experimentalDecorators": true,
"module": "esnext",
"moduleResolution": "node",
"importHelpers": true,
"target": "es2015",
"typeRoots": [
"node_modules/@types"
],
"lib": [
"es2018",
"dom"
],
"types": ["angular"]
},
"angularCompilerOptions": {
"fullTemplateTypeCheck": true,
"strictInjectionParameters": true
}
}
tsconfig.app.json
{
"extends": "./tsconfig.json",
"compilerOptions": {
"outDir": "./out-tsc/app",
"types": ["angular"]
},
"files": [
"src/main.ts",
"src/polyfills.ts"
],
"include": [
"src/**/*.d.ts"
],
"exclude": [
"src/test.ts",
"src/**/*.spec.ts"
]
}
包.json
{
"name": "myproj",
"version": "4.5.0",
"start": "ng serve -aot",
"scripts": {
"ng": "ng",
"start": "ng serve",
"build": "ng build",
"test": "ng test",
"lint": "ng lint",
"e2e": "ng e2e"
},
"private": true,
"dependencies": {
"@angular/animations": "~9.0.5",
"@angular/cdk": "~9.1.1",
"@angular/common": "~9.0.5",
"@angular/compiler": "~9.0.5",
"@angular/core": "~9.0.5",
"@angular/fire": "^5.4.2",
"@angular/forms": "~9.0.5",
"@angular/material": "^9.1.1",
"@angular/platform-browser": "~9.0.5",
"@angular/platform-browser-dynamic": "~9.0.5",
"@angular/router": "~9.0.5",
"@angular/upgrade": "^9.0.5",
"@ng-idle/core": "^8.0.0-beta.4",
"@ng-idle/keepalive": "^8.0.0-beta.4",
"@uirouter/angular": "^6.0.1",
"@uirouter/angular-hybrid": "^10.0.1",
"@uirouter/angularjs": "^1.0.25",
"@uirouter/core": "^6.0.4",
"@uirouter/rx": "^0.6.5",
"angular": "^1.7.9",
"foundation-sites": "^6.6.1",
"install": "^0.13.0",
"ng-block-ui": "^2.1.8",
"ngx-cookie-service": "^2.4.0",
"ngx-foundation": "^1.0.8",
"ngx-pendo": "^1.2.3",
"ngx-perfect-scrollbar": "^8.0.0",
"npm": "^6.14.2",
"rxjs": "~6.5.4",
"tslib": "^1.10.0",
"upgrade": "^1.1.0",
"zone.js": "~0.10.2"
},
"devDependencies": {
"@angular-devkit/build-angular": "~0.900.5",
"@angular/cli": "~9.0.5",
"@angular/compiler-cli": "~9.0.5",
"@angular/language-service": "~9.0.5",
"@types/angular": "^1.6.57",
"@types/jasmine": "~3.3.8",
"@types/jasminewd2": "~2.0.3",
"@types/node": "^12.11.1",
"codelyzer": "^5.1.2",
"jasmine-core": "~3.4.0",
"jasmine-spec-reporter": "~4.2.1",
"karma": "~4.1.0",
"karma-chrome-launcher": "~2.2.0",
"karma-coverage-istanbul-reporter": "~2.0.1",
"karma-jasmine": "~2.0.1",
"karma-jasmine-html-reporter": "^1.5.2",
"protractor": "^5.4.3",
"ts-node": "~7.0.0",
"tslint": "~5.15.0",
"typescript": "~3.7.5"
}
}
我遇到了同样的问题,就我而言,它是在启用严格模式后发生的。 我通过从package.json
删除"sideEffects": false
来修复它
我也有同样的问题。
首先,我尝试在 tsconfig.app.json 中禁用 Ivy,它工作正常。 得出的结论是,问题出在常春藤上。 感谢@user2846469
"angularCompilerOptions": {
"enableIvy": false
}
Github Issue在后面的评论中清楚地描述了问题和解决方案
Ivy 不会将降级的组件包含到生产构建中 如果降级的组件仅在 AngularJS 模板中使用 - 它会随着生产构建从树中脱离 - 这表现在组件没有被渲染。 默默。 没有错误、警告或任何其他内容。
import './downgrade.component';
要么像上面一样导入你的组件,要么考虑在与 NgModule 相同的文件中注册降级的组件。
我有一个类似的问题,但使用非混合应用程序 - 一个全新的从头开始构建的 Angular 10 应用程序,所以我在这里记录它,以防其他开发人员遇到类似问题。
正如@viral-rathod 所指出的,禁用 Ivy 也解决了我的问题:
在tsconfig.base.json
添加到angularCompilerOptions
设置"enableIvy": false
所以问题似乎是相似的:启用 Ivy 后,某些组件在生产构建中(但在开发运行中没有)从树中脱离出来,因此,组件完全无法渲染,静默且没有错误或生成视图.
就我而言,问题在于组件 A 的文件有一些用于渲染组件 A 模板的小辅助组件(每个不超过 20 行代码,包括模板和样式),并且运行良好。 当组件 B 尝试在其模板中使用相同的辅助组件时(仅在模板中使用它们而未在其他任何地方提及) - 虽然它在开发中运行良好,但在生产中却失败了:组件 B 完全无法渲染任何东西。
将辅助组件直接导入 B 的文件 - 作为 Viral 的回答建议的解决方法 - 没有做任何事情。
我的解决方案是将辅助组件移动到它们自己的文件中,并在从它们自己的文件中导入它们后将它们注册到NgModule
。 组件 A 或 B 都不需要更改(除了从 A 的文件中删除重复的行)。
对我来说,问题是:
我错误地使用了带有路径的斜杠: /teams
const routes: Routes = [
{path: "", component: HomeComponent},
{path: "/teams", component: TeamsComponent}
];
相反,它应该是: teams
const routes: Routes = [
{path: "", component: HomeComponent},
{path: "teams", component: TeamsComponent}
];
感谢浏览器控制台。
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.