美文网首页基础前端
webpack DefinePlugin 的奇妙用处

webpack DefinePlugin 的奇妙用处

作者: CondorHero | 来源:发表于2019-10-26 21:19 被阅读0次

    这是一个简单的字符串替换插件,将我们所有经过 webpack 打包的 js 文件的对应的字符串都替换为我们在这个插件中指定的字符串。DefinePlugin 允许创建一个在编译时可以配置的全局常量。

    首先我们的在 webpack.config.js 里面进行配置一下:

    const webpack = require('webpack');
    plugins: [
        new webpack.DefinePlugin({
            TWO_0 : "1+1",
            TWO_1 : "'1+1'",
            TWO_2 : JSON.stringify("1+1"),
            "弹窗一下": "alert('我弹窗了')"
        })
    ],
    

    注意注意:webpack.DefinePlugin 里面的 key 在组件里面可以直接作为变量使用。这时候我们在一个组件里面例如在 App 组件里面进行调试:

    import React, { Component } from "react";
    export default class App extends Component {
        constructor(){
            super()
        }
        render() {
                弹窗一下
                console.log(TWO_0)
                console.log(TWO_1)
                console.log(TWO_2)
            return (
                <div>
                    <h1>
                        {弹窗一下}
                    </h1>
                </div>
            )
        }
    }
    

    执行结果是什么?

    1. 弹出一个警告框
    2. 控制台输出 2
    3. 控制台输出 1 + 1
    4. 控制台输出 1+ 1
    5. 弹出一个警告框

    通过结果我们很明显的知道 webpack.DefinePlugin 配置里面的值,如果是只有一层引号的话会直接执行掉,这时候值作为表达式和变量使用,但是如果我们想要字符串,不让 1 + 1 执行的话,两种办法,一:"'1 + 1'"'"1 + 1"'。二:JSON.stringify('1 + 1'),这就叫做环境变量的值必须是由双引号包裹的字符串。

    DefinedPlugin 定义的环境变量只对 webpack 需要处理的代码有效,不会影响 nodejs 运行的环境变量。
    常见的应用场景:

    • 「生产/开发」构建中使用不同的服务 URL
    new webpack.DefinePlugin({
      'SERVICE_URL': JSON.stringify("http://dev.example.com")
    })
    
    重点 对于 webpack3 以下的低版本充当 webpack4 的 mode。用来指定 webpack 的打包环境。
    new webpack.DefinePlugin({
        "process.env.NODE_ENV":JSON.stringify("production")
    })
    

    老版本的 "process.env.NODE_ENV":JSON.stringify("production")的作用:

    • process 是 node 的全局变量,并且 process 有 env 这个属性,但是没有 NODE_ENV 这个属性。
    • webpack4 以上版本:通过设置 mode ,process.env.NODE_ENV会自动得到值。


    • webpack3 或者以下 就的 通过 webpack 自带的一个插件 DefinePlugin 完成设置工作,采用这种方式设置的时候,值对应的格式必须是"'env'"这种格式,所以会JSON.stringify 进行转换。这时候的 "process.env.NODE_ENV":JSON.stringify("production") 就相当于 webpack4 的 mode 模式。
      理解webpack中的process.env.NODE_ENV

    相关文章

      网友评论

        本文标题:webpack DefinePlugin 的奇妙用处

        本文链接:https://www.haomeiwen.com/subject/rsgyvctx.html