Angular 5 webpack 3 aot

标签 angular webpack angular5 angular-aot

我正在尝试使用 webpack 3 和 angular 5 进行 aot 构建,但是网上有很多教程,但没有一个毫无疑问地展示完整的示例,到目前为止,我有以下配置: (对于那些对路径有疑问的人——我在 java 应用程序中使用它)

webpack.config.aot.js:

const webpack = require("webpack");
const ExtractTextPlugin = require("extract-text-webpack-plugin");
const ngToolsWebpack = require('@ngtools/webpack');

module.exports = {
    context: __dirname + "/src/main/webapp/resources/script/",
    entry: {
        app: "./core/main.aot.ts",
        vendor: "./vendor.ts",
        polyfills: "./polyfills.ts"
    },
    output: {
        filename: 'js/[name].js',
        chunkFilename: "js/chunks/[id].chunk.js",
        publicPath: "resources/compiled/",
        path: __dirname + '/src/main/webapp/resources/compiled'
    },
    resolve: {
        alias: {
            STYLES: __dirname + "/src/main/webapp/resources/css/",
            SCRIPT: __dirname + "/src/main/webapp/script/"
        },
        extensions: [".js", ".json", ".scss", ".ts"]
    },
    module: {
        rules: [
            {
                test: /[\/]angular\.js$/,
                loader: 'exports-loader?angular'
            },
            {
                test: /\.html$/,
                loader: 'raw-loader'
            },
            {
                test: /(?:\.ngfactory\.js|\.ngstyle\.js|\.ts)$/,
                loader: '@ngtools/webpack'
            }
        ]
    },
    plugins: [
        new ngToolsWebpack.AngularCompilerPlugin({
            tsConfigPath: './tsconfig.aot.json',
            entryModule: './src/main/webapp/resources/script/core/i18n/app.module.en#AppModule'
        })
    ]
};

tsconfig.aot.json:

{
  "compilerOptions": {
    "module": "es2015",
    "moduleResolution": "node",
    "target": "es5",
    "noImplicitAny": false,
    "sourceMap": true,
    "mapRoot": "",
    "emitDecoratorMetadata": true,
    "experimentalDecorators": true,
    "lib": [
      "es2015",
      "dom"
    ],
    "outDir": "lib",
    "skipLibCheck": true,
    "rootDir": "."
  },
  "exclude": [
    "node_modules/*",
    "target/*"
  ],
  "angularCompilerOptions": {
    "genDir": "./src/main/webapp/resources/script/factory",
    "rootDir": ".",
    "baseUrl": "/"
  }
}

main.aot.ts:

import {platformBrowser} from '@angular/platform-browser';
import {enableProdMode} from "@angular/core";
import {AppModuleNgFactory} from '../factory/app/app.module.ngfactory';

enableProdMode();

platformBrowser().bootstrapModuleFactory(AppModuleNgFactory);

文件结构(简化):

- webpack.config.aot.js
- tsconfig.aot.js
- src/
  - main/
    - webapp/
      - resources/
        - script/
          - vendor.ts
          - polyfills.ts
          - core/
            - main.aot.ts
            - i18n/
              - app.module.en.ts

(如果我没有展示相关内容,请告诉我)

因此,当我尝试使用 webpack -p --config ./webpack.config.aot.js

构建它时

出现以下错误:

ERROR in src/main/webapp/resources/script/core/main.aot.ts(5,34): error TS2307: Cannot find module '../factory/app/app.module.ngfactory'.

这听起来很合理,因为那里没有 AppModuleNgFactory,但正如我在教程中看到的那样,它应该是在 aot 构建时使用 genDir 生成的,对吗? (请注意,如果我省略了 app/文件夹,所以路径看起来是 '../factory/app.module.ngfactory' 我得到同样的错误)

使用@ngtools/webpack 指向 aot 构建中不存在的 AppModuleNgFactory 是否正确?

AppModuleNgFactory 是什么?在 Angular 站点上几乎没有关于它的任何文档

我应该在我的配置中更改什么才能成功生成 aot 构建?

如果我将主文件更改为引导 AppModule 本身,它会成功构建,但在浏览器中我会收到 NullInjectorError: No provider for t! 错误

没有缩小它显示:没有 CompilerFactory 的提供者!

最佳答案

@ngtools/webpack 似乎可以从原始主文件处理引导模块工厂本身,例如 webpack 条目应该是:path_to_file/main.ts

并且 main.ts 包含:

platformBrowserDynamic().bootstrapModule(AppModule);

整个事情将自行处理,无需额外配置!

真的很厉害

关于Angular 5 webpack 3 aot,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/47365240/

相关文章:

webpack - 如何修复 webpack 输出的图像 src 中的 [Object Module]?

javascript - 我可以在 Angular 和 Node 之间共享服务吗?

带有 ngFor 的 Angular Flex 布局,每行 X 个元素

angular - 在 ngFor 中声明变量

karma-runner - 使用 karma 和 webpack : _karma_webpack_ - no such file or directory 进行单元测试

对象的 Angular 自然排序数组

javascript - Angular 5 动态添加和删除组件实例

javascript - 如何在 angular2 中使用 ngx-translate 获取当前语言

angular - ng-bootstrap typeahead TypeError : Object(. ..) 不是函数

javascript - Vue2 : view-router exception when trying to use <router-view>