1

我正在尝试使用 webpack-4 来获取 react 的生产版本(该项目不是使用创建 React App 创建的),但没有成功。我的项目正在使用 typescript 并使用 ts-loader 并使用 React 15.6.2 的版本。

当前的 webpack 配置文件

const path = require("path");

module.exports = {
    entry: ['./lib/tproj/js/index.ts'],
    output: {
        filename: './dist/tproj/js/bundle.js'
    },
    devtool: "source-map",
    resolve: {
        extensions: ['.webpack.js', '.web.js', '.ts', '.tsx', '.js', '.json']
    },
    module: {
        rules: [
            {
                test: /\.tsx?$/,
                exclude: [
                    /lib\/tests/,
                    /lib\/tproj\/elasticsearch/,
                    /lib\/tproj\/expressserver/
                ],
                loader: "ts-loader"
            },
            {
                test: /\.js$/,
                enforce: "pre",
                loader: "source-map-loader"
            }
        ]
    }
};

我已尝试按如下方式对其进行修改,但仍然无法正常工作。

const path = require("path");
const webpack = require("webpack");
const TerserPlugin = require('terser-webpack-plugin');

var config = {
    entry: ['./lib/tproj/js/index.ts'],
    output: {
        filename: './dist/tproj/js/bundle.js'
    },
    resolve: {
        extensions: ['.webpack.js', '.web.js', '.ts', '.tsx', '.js', '.json']
    },
    module: {
        rules: [
            {
                 test: /\.tsx?$/,
                exclude: [
                    /lib\/tests/,
                    /lib\/tproj\/elasticsearch/,
                    /lib\/tproj\/expressserver/
                ],
                loader: "ts-loader"
            },
            {
                test: /\.css$/,
                use: ['style-loader', 'css-loader'],
            }
        ]
    },
    mode: 'production',
    optimization: {
        minimize: true,
        minimizer: [new TerserPlugin()],
        splitChunks: {
            chunks: 'all',
        }
    }

};

module.exports = (env, argv) => {

    if (argv.mode === 'development') {
        config.devtool = 'source-map';
    }

    if (argv.mode === 'production') {
        config.devtool = 'false';
    }

    return config;
}
;

仍然是 webpack 和 React 的新手。 提前感谢您的任何帮助或建议。

4

4 回答 4

1

React 在 index.js 文件中包含 dev 和 prod 版本之间的切换。 在此处输入图像描述

构建后检查process.env.NODE_ENV代码中的值。

于 2020-01-09T00:13:04.923 回答
0

感谢大家的建议和帮助,问题是因为没有创建 bundle.js 文件,我最近将 webpack 的版本更新为 4

所以而不是

output: {
        filename: './dist/tproj/js/bundle.js'
    },

使用这个对我有用

output: {
        path: path.resolve(__dirname, "./dist/tproj/js/"),
        filename: "bundle.js",
    },
于 2020-01-09T01:09:32.217 回答
0

确保在运行 webpack 时是否更改了 bundle.js

于 2020-01-09T02:29:39.957 回答
0

在您的 webpack 配置中,将其添加到 plugins 数组中。

new webpack.DefinePlugin({
  'process.env': {
    NODE_ENV: JSON.stringify('production')
  }
})

这定义了正确的环境变量,以响应运行生产构建。

var config = {
    entry: ['./lib/tproj/js/index.ts'],
    output: {
        filename: './dist/tproj/js/bundle.js'
    },
    resolve: {
        extensions: ['.webpack.js', '.web.js', '.ts', '.tsx', '.js', '.json']
    },
    module: {
        rules: [
            {
                 test: /\.tsx?$/,
                exclude: [
                    /lib\/tests/,
                    /lib\/tproj\/elasticsearch/,
                    /lib\/tproj\/expressserver/
                ],
                loader: "ts-loader"
            },
            {
                test: /\.css$/,
                use: ['style-loader', 'css-loader'],
            }
        ]
    },
    mode: 'production',
    optimization: {
        minimize: true,
        minimizer: [new TerserPlugin()],
        splitChunks: {
            chunks: 'all',
        }
    },
    plugins: [
      new webpack.DefinePlugin({
        'process.env': {
          NODE_ENV: JSON.stringify('production')
        }
      })
    ]
};
于 2020-01-09T00:19:41.823 回答