繁体   English   中英

Angular 9 项目在生产环境中不起作用

[英]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.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM