webpack中mode、NODE_ENV、DefinePlugin、cross-env的使用

在这里插入图片描述

本文讲的全部知识点,都是和webpack相关的。如果你之前有疑问,那本文一定能帮你搞清楚。

问题来源一般是类似下面代码(webpack.json中):

"scripts": {"dev": "cross-env NODE_ENV=development webpack-dev-server --config ./config/webpack.config.dev.js"},

代码中出现的:cross-envNODE_ENV。还有webpack.config.js中设置的modeDefinePlugin

环境版本(如果是低版本下面也会提及):

  • webpack < v4
  • webpack-dev-server < v4
  • cross-env < v5

编译环境和运行环境

在讲下面之前,我们必须清楚什么是编译环境,什么是运行环境?

  • 编译环境(node环境)

我们在终端执行:npm run devnpm run start 或打包 npm run build 都是在编译环境,也就是node环境。所以webpack的配置文件 webpack.config.jswebpack.dev.jswebpack.production.js 是运行在编译环境中的。

  • 运行环境(浏览器环境)

我们写的业务代码等都是在浏览器中运行的,也就是打包之后我们的代码还在的。

只有区分这两个环境,才能理解下面不同配置方式,有时能读取到,有时读取不到的原因.

概念

mode

模式, webpack会根据mode的值做一些内置优化。

枚举值:none, developmentproduction(默认)。 只能是这三个值中某一个。

配置方式:

  • 方式一(推荐)

在webpack配置文件(webpack.config.js、webpack.develop.js、webpack.production.js)中设置:

module.exports = {mode: 'development'
};
  • 方式二

package.json中,webpack的CLI命令参数:

webpack serve --mode=development

这两种方式设置的mode值,只能在业务代码(运行环境)中通过process.env.NODE_ENV读取到;在编译环境,webpack配置文件中是读取不到的。

注意:

webpack 4+ 中,你不需要做任何设置(其实是webpack自动帮你把变量加到了DefinePlugin中)就可以在代码中读取process.env.NODE_ENV的值了。

但是在 webpack 3 及其更低版本中,你需要在webpack配置文件中使用 DefinePlugin设置成全局变量,才可以访问得到:

var webpack = require('webpack')module.exports = {// ...plugins: [// ...new webpack.DefinePlugin({'process.env.NODE_ENV': JSON.stringify('production')})]
}

NODE_ENV

上面我们设置mode,是在运行环境中使用;如果想在编译环境(webpack配置文件中使用)就需要用到NODE_ENV了。

本质就是给当前Node进程,设置一个环境变量。只有在当前Node进程中有效。

设置方式:

package.json中:

{"scripts": {"dev": "NODE_ENV=development webpack-dev-server --config webpack.dev.config.js"}
}

你如果是mac电脑执行npm run dev是能正常运行的,但如果你是windows电脑,会报错:

'NODE_ENV' 不是内部或外部命令,也不是可运行的程序或批处理文件。

是的,在windows里面需要修改命令为:

{"scripts": {"dev": "set NODE_ENV=development && webpack-dev-server --config ./config/webpack.config.dev.js"}
}

要解决跨环境问题,就要用到下面的cross-env了,我们一会在讲,还是先回来。

设置了NODE_ENV=development后,在哪使用,如何使用呢?

答案:只能在编译环境(webpack的配置文件webpack.config.js等)中使用。可以通过**process.env.NODE_ENV读取。**在业务代码中是无法读取的。

cross-env

为解决跨环境问题。

安装:

npm install cross-env@5

修改package.json中命令:

{"scripts": {"dev": "cross-env NODE_ENV=development webpack-dev-server --config webpack.dev.config.js"}
}

这样在macwindows中就都可以执行npm run dev了。

DefinePlugin

上面在讲mode时已经提到了DefinePlugin ,它主要用来定义一些全局变量,并会在 编译时 将你代码中的全局变量替换为具体值。这在需要根据开发模式与生产模式进行不同的操作时,非常有用。

new webpack.DefinePlugin({// 定义...
});
使用

传递给 DefinePlugin 的每个键都是一个标识符或多个以 . 连接的标识符。

  • 如果该值为字符串,它将被作为代码片段来使用。
  • 如果该值不是字符串,则将被转换成字符串(包括函数方法)。
  • 如果值是一个对象,则它所有的键将使用相同方法定义。
  • 如果键添加 typeof 作为前缀,它会被定义为 typeof 调用。

这些值将内联到代码中,从而允许通过代码压缩来删除冗余的条件判断。

new webpack.DefinePlugin({PRODUCTION: JSON.stringify(true),'process.env.NODE_ENV': JSON.stringify(process.env.NODE_ENV),
});

提示:

请注意,由于本插件会直接替换文本,因此提供的值必须在字符串本身中再包含一个 实际的引号 。通常,可以使用类似 '"production"' 这样的替换引号,或者直接用 JSON.stringify('production')

if (!PRODUCTION) {console.log('Debug info');
}if (PRODUCTION) {console.log('Production log');
}

未经 webpack 压缩过的代码:

if (!true) {console.log('Debug info');
}
if (true) {console.log('Production log');
}

经过压缩后:

console.log('Production log');

cross-env + DefinePlugin

确切的讲,使用cross-env可以定义任意Node全局环境变量,例如package.json中:

{"scripts": {"dev": "cross-env NODE_ENV=development PUBLIC_PATH=/ui webpack-dev-server --config webpack.dev.config.js"}
}

我们这里又新增了一个全局变量PUBLIC_PATH,用来设置URL基础路径。

在编译环境(webpack.config.js)中,可以直接使用process.env.PUBLIC_PATH获取。

并可以通过添加到DefinePlugin,在代码中使用

new webpack.DefinePlugin({PUBLIC_PATH: JSON.stringify(process.env.PUBLIC_PATH),
});

定义之后就可以在代码中使用了:

const url = PUBLIC_PATH + '/views'
console.log(url); // =>'/ui/views'

总结

  1. mode是设置执行模式,webpack4会自动将mode的值通过DefinePlugin设置为全局变量,业务代码中可以使用process.env.NODE_ENV读取值。
  2. NODE_ENV是设置Node环境变量,在webpack.config.js、webpack.dev.js等文件中通过process.env.NODE_ENV读取值。
  3. cross-env是用来解决跨环境的。
  4. DefinePlugin用来设置全局变量,在业务代码中通过process.env.xxx读取值。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.hqwc.cn/news/643504.html

如若内容造成侵权/违法违规/事实不符,请联系编程知识网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

提升你的C编程技能:使用cURL下载Kwai视频

概述 本文将介绍如何利用C语言以及cURL库来实现Kwai视频的下载。cURL作为一个功能强大的网络传输工具&#xff0c;能够在C语言环境下轻松地实现数据的传输。我们还将探讨如何运用代理IP技术&#xff0c;提升爬虫的匿名性和效率&#xff0c;以适应Kwai视频平台的发展趋势。 正…

探索设计模式的魅力:主从模式与AI大模型的结合-开启机器学习新纪元

​&#x1f308; 个人主页&#xff1a;danci_ &#x1f525; 系列专栏&#xff1a;《设计模式》 &#x1f4aa;&#x1f3fb; 制定明确可量化的目标&#xff0c;坚持默默的做事。 ✨欢迎加入探索主从模式与AI大模型之旅✨ &#x1f31f;Hey, tech enthusiasts! 你是否还在追…

parallels desktop19.3最新版本软件新功能详细介绍

Parallels Desktop是一款运行在Mac电脑上的虚拟机软件&#xff0c;它允许用户在Mac系统上同时运行多个操作系统&#xff0c;比如Windows、Linux等。通过这款软件&#xff0c;Mac用户可以轻松地在同一台电脑上体验不同操作系统的功能和应用程序&#xff0c;而无需额外的硬件设备…

codeforce#933 题解

E. Rudolf and k Bridges 题意不讲了&#xff0c;不如去题干看图。 传统dp&#xff0c;每个点有两个选择&#xff0c;那么建桥要么不建。需要注意的是在状态转移的时候&#xff0c;桥是有长度的&#xff0c;如果不建需要前d格中建桥花费最少的位置作为状态转移的初态。 #incl…

【前后端】django与vue的结合使用

提示&#xff1a;文章写完后&#xff0c;目录可以自动生成&#xff0c;如何生成可参考右边的帮助文档 文章目录 前言一、前后端分离的简介二、django与vue的结合使用三、总结 前言 随着开发语言及人工智能工具的普及&#xff0c;使得越来越多的人会主动学习使用一些开发工具&a…

的记忆:pandas(实在会忘记,就看作是一个 Excel 表格,或者是 SQL 表,或者是字典的字典。)

pandas 是一个开源的 Python 数据分析库&#xff0c;它提供了快速、灵活和富有表现力的数据结构&#xff0c;旨在使“关系”或“标记”数据的“快速分析、清洗和转换”变得既简单又直观。pandas 非常适合于数据清洗和转换、数据分析和建模等任务。以下是 pandas 的基本概念和主…

多商家AI智能名片商城系统(开源版)——构建高效数字化商业新生态

一、项目概述 1、项目背景 1&#xff09;起源 随着数字化时代的快速发展&#xff0c;传统名片和商城系统已经难以满足企业日益增长的需求。商家需要更高效、更智能的方式来展示自己的产品和服务&#xff0c;与消费者进行互动和交易。同时&#xff0c;开源技术的普及也为开发…

ZYNQ--PL读写PS端DDR数据

PL 和PS的高效交互是zynq 7000 soc开发的重中之重&#xff0c;我们常常需要将PL端的大量数 据实时送到PS端处理&#xff0c;或者将PS端处理结果实时送到PL端处理&#xff0c;常规我们会想到使用DMA 的方式来进行&#xff0c;但是各种协议非常麻烦&#xff0c;灵活性也比较差&am…

“三三裂变”,实体书营销实操细节分享……

“三三裂变”实操细节 一、实验结果 “三三裂变”的实验,结果比较好。就是我们大概有300人报名,但实际行动的只有109人,大概有103人都完成了三个人的目标,也就是说我们通过109人裂变了475人,利润率是1:4.5左右,整个裂变的效率还是可以的,也就是说: 如果你用这种方法有…

MATLAB 数据类型

MATLAB 数据类型 MATLAB 不需要任何类型声明或维度语句。每当 MATLAB 遇到一个新的变量名&#xff0c;它就创建变量并分配适当的内存空间。 如果变量已经存在&#xff0c;那么MATLAB将用新内容替换原始内容&#xff0c;并在必要时分配新的存储空间。 例如&#xff0c; Tota…

哪些因素影响了PCB电路板切割精度?

PCB电路板切割是电子制造过程中一个至关重要的环节&#xff0c;其精度对后续工序的质量和效率具有决定性影响。因此&#xff0c;了解影响PCB电路板切割精度的原因&#xff0c;对于提高电子产品的质量和生产效率具有重要意义。 1. PCB分板机稳定性 PCB分板机的性能直接影响到切…

STM32点灯大师(中断法)

一、使用CubeMX配置 新增加了RCC进行配置 二、代码 需要重写虚函数&#xff0c;给自己引用