问答

webpack配置process.env问题

作者:admin 2021-04-22 我要评论

今天学webpack配置的时候,按照教程里面的配置,发现一个不明白的地方,用的是旧版本的webpack3.12.0, 以下是配置: const path = require('path')const HTMLPlu...

在说正事之前,我要推荐一个福利:你还在原价购买阿里云、腾讯云、华为云服务器吗?那太亏啦!来这里,新购、升级、续费都打折,能够为您省60%的钱呢!2核4G企业级云服务器低至69元/年,点击进去看看吧>>>)

今天学webpack配置的时候,按照教程里面的配置,发现一个不明白的地方,用的是旧版本的webpack3.12.0, 以下是配置:

const path = require('path')
const HTMLPlugin = require('html-webpack-plugin')
const { webpack } = require('webpack')

const isDev = process.env.NODE_ENV === 'development'

const config = {
    target: 'web',
    entry: path.join(__dirname, 'src/index.js'),
    output: {
        filename: 'bundle.js',
        path: path.join(__dirname, 'dist')
    },
    module: {
        rules: [
            {
                test: /\.vue$/,
                loader: 'vue-loader'
            },
            {
                test: /\.css$/,
                use: [
                    'style-loader',
                    'css-loader'
                ]
            },
            {
                test: /\.(gif|jpg|jpeg|png|svg)$/,
                use: [
                    {
                        loader: 'url-loader', // 转换为base64代码,依赖file-loader
                        options: {
                            limit: 1024,
                            name: '[name]-a.[ext]'
                        }
                    }
                ]
            },
            {
                test: /\.styl$/,
                use: [
                    'style-loader',
                    'css-loader',
                    'stylus-loader'
                ]
            }
        ]
    },
    plugins: [
        new webpack.DefinePlugin({
            'process.env': {
                NODE_ENV: isDev ? '"development' : '"production'
            }
        }),
        new HTMLPlugin()
    ]
}

if (isDev) {
    config.devServer = {
        port: 8000,
        host: '0.0.0.0',
        overlay: {
            errors: true
        }
    }
} 

module.exports = config

我不明白的是为什么plugins配置项里面要加上webpack.DefinePlugin这个设置,这个设置具体是干嘛的,这里面设置了process.env,
image.png
但是之前代码第5行已经通过const isDev = process.env.NODE_ENV === 'development'配置过了啊
image.png

后面new webpack.DefinePlugin里面再配置一次不是矛盾多此一举吗?就这里想不明白,请教一下各位大佬

还有就是webpack我发现版本好多啊,有3有4有5,到底应该学哪个版本的比较好呢?谢谢!

###

const isDev = process.env.NODE_ENV === 'development'仔细看,这不是配置,isDev是布尔值,===是逻辑判断。

new webpack.DefinePlugin是定义全局变量。

学哪个…我是当工具,熟悉常规的配置,看看更新,用啥查啥

###

两个 process.env.NODE_ENV 的位置不同,上面那个 isDev 仅在 node.js,也就是 webpack 打包的时候起作用;通过 DefinePlugin 注入的那个会在你的业务代码中起作用。

学哪个?这个问题很容易回答:

  1. 如果你的项目明天就要上线,学你最熟悉的
  2. 否则,学最新的,目前是 webpack5

版权声明:本文转载自网络,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接和本声明。本站转载出于传播更多优秀技术知识之目的,如有侵权请联系QQ/微信:153890879删除

相关文章
  • 求助!Mysql workbench connections出

    求助!Mysql workbench connections出

  • c++ 的dll 转golang可以调用

    c++ 的dll 转golang可以调用

  • c++的 new int{10}  和 new int(10) 有

    c++的 new int{10} 和 new int(10) 有

  • Grafana MySQL为数据源时, 折线图无法

    Grafana MySQL为数据源时, 折线图无法

腾讯云代理商
海外云服务器