首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >问答首页 >在运行构建命令时,Nestjs不使用webpack配置文件。

在运行构建命令时,Nestjs不使用webpack配置文件。
EN

Stack Overflow用户
提问于 2022-07-25 09:18:24
回答 1查看 489关注 0票数 2

我有一个Node代码,我试图与nestjs和webpack一起构建它。我尝试使用webpack.DefinePlugin注入全局变量,但在构建结果中,我可以看到未替换的变量。

nest-cli.json文件:

代码语言:javascript
运行
复制
{
    "$schema": "https://json.schemastore.org/nest-cli",
    "collection": "@nestjs/schematics",
    "sourceRoot": "src",
    "compilerOptions": {
        "webpack": true,
        "webpackConfigPath": "./webpack.config.ts"
    }
}

webpack.config.ts文件:

代码语言:javascript
运行
复制
import webpack from 'webpack';
import WebpackShellPluginNext from 'webpack-shell-plugin-next';
import isCI from 'is-ci';

const isDev = process.env.NODE_ENV === 'development' && !isCI;
const cliApiDomain = isDev ? 'localhost' : 'xxx.xxx';
const cliApiUrl = isDev ? 'http://localhost:5000' : 'https://www.xxx.xxx';
const dashboardUrl = isDev ? 'http://localhost:8080' : 'https://xxx.xxxx';

const configuration = (options: webpack.Configuration): webpack.Configuration => ({
    ...options,
    plugins: [
        ...options.plugins!,
        new WebpackShellPluginNext({
            onBuildStart: {
                scripts: ['rimraf dist'],
                blocking: true,
            },
            safe: true,
        }),
        new webpack.DefinePlugin({
            __CLI_API_DOMAIN__: `'${cliApiDomain}'`,
            __CLI_API_URL__: `'${cliApiUrl}'`,
            __DASHBOARD_URL__: `'${dashboardUrl}'`,
        }),
    ],
});

export default configuration;

我有用于在开发模式和生产模式下运行的package.json脚本:

代码语言:javascript
运行
复制
.
.
.
        "build": "nest build",
        "build:dev": "cross-env NODE_ENV=development nest build",
.
.
.

我在源代码中使用了配置的变量:

代码语言:javascript
运行
复制
    private config: IConfig = {
        API_URL: __CLI_API_URL__,
        DASHBOARD_URL: __DASHBOARD_URL__,
    };

然而,这些变量并没有被webpack所取代。当我检查我的构建代码时,我可以看到这些变量仍然在我的代码中。

我希望看到他们被替换。看起来Nestjs甚至不使用我的文件

在将webpack.config.ts文件转换为使用相同逻辑但使用js:webpack.config.js之后,它就工作了。Nestjs不支持TS配置文件?

问题是。NestJS忽略用TypeScript编写的Webpack文件。

EN

回答 1

Stack Overflow用户

发布于 2022-10-17 13:03:34

我通过用webpack 1替换JavaScript配置文件来解决这个问题,因为NestJS不支持用TypeScript编写的配置文件。

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

https://stackoverflow.com/questions/73106764

复制
相关文章

相似问题

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