首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >问答首页 >角9工程不在生产环境中工作

角9工程不在生产环境中工作
EN

Stack Overflow用户
提问于 2020-03-10 09:01:13
回答 4查看 9.3K关注 0票数 13

我已经将我们的角度混合项目从8迁移到9。迁移变得很顺利,ng构建/ ng服务也像以前一样运行良好。

真正的问题,我不知道如何开始工作,是在我为生产而构建应用程序之后(比如build )。该项目的着陆页面是完全空白的,没有JS错误,没有控制台警告。看起来AppModule没有加载吗?我们唯一需要做的更改是与main.aot.ts文件相关,我们删除了该文件,因为它不再适用于常春藤编译器。

任何相关的经验,你可能在过去将帮助我,非常感谢!

main.ts看起来像这样

代码语言:javascript
运行
复制
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)

代码语言:javascript
运行
复制
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 });

tsconfig.json

代码语言:javascript
运行
复制
{
  "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

代码语言:javascript
运行
复制
{
  "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"
  ]
}

package.json

代码语言:javascript
运行
复制
{
  "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"
  }
}
EN

回答 4

Stack Overflow用户

发布于 2020-06-17 05:59:21

我也有同样的问题。

首先,我尝试在tsconfig.app.json中禁用常春藤,它运行得很好。得出的结论是艾薇的问题。感谢@ Thanks 2846469

代码语言:javascript
运行
复制
"angularCompilerOptions": {
   "enableIvy": false
}

Github问题在后面的注释中清楚地描述了问题和解决方案。

如果降级组件仅在AngularJS模板中使用,则常春藤不将降级组件包含到生产构建中--它将随着产品构建而从树中分离出来--这体现在组件本身,只是没有呈现。默默地。没有错误警告什么的。

代码语言:javascript
运行
复制
import './downgrade.component';

或者像上面那样导入组件,或者考虑在与NgModule相同的文件中注册降级的组件。

票数 4
EN

Stack Overflow用户

发布于 2020-07-24 20:36:09

我也有同样的问题,在我的例子中,它是在启用严格模式之后发生的。我通过从"sideEffects": false中删除package.json来修复它

票数 4
EN

Stack Overflow用户

发布于 2020-09-05 19:50:50

我有一个类似的问题,但与一个非混合应用程序-一个全新的从零角度10构建的应用程序,所以我在这里记录它,以防其他开发人员结束了类似的问题。

正如@viral所指出的,禁用常春藤也解决了我的问题:

tsconfig.base.json中向angularCompilerOptions添加设置"enableIvy": false

因此,问题似乎类似:启用了常春藤之后,一些组件在生产构建中被从树中移出(但在dev运行中没有),因此,组件完全无法以静默方式呈现,没有错误或生成视图。

在我的例子中,问题是组件A的文件中有一些微小的助手组件(每个代码不超过20行,包括模板和样式),这些组件被用来呈现组件A的模板,并且工作得很好。当组件B试图在其模板中使用相同的辅助组件时(只在模板中使用它们,而没有在其他地方提及)--虽然它在开发中运行良好,但在生产中失败:组件B完全不能呈现任何内容。

将助手组件直接导入B的文件--这是病毒的答案所建议的解决办法--没有做任何事情。

对我来说,解决方案是将助手组件移动到它们自己的文件中,并在从自己的文件中导入它们之后在NgModule中注册它们。组件A或B不需要更改(除了从A的文件中删除重复行外)。

票数 2
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/60614292

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档