一、process.env.NODE_ENV是什么?
在vue项目中,process.env读取的是env文件里全局环境变量, 其中我们常用NODE_ENV来区分生产环境or开发环境。
二、 这个变量如何配置
这个变量是用户自定义的,配置在package.json里。
如果没有配置,就是默认的dev是developmet,build:prod是Production,其他命令默认都是development。
以下是错误的配置方法(引以为戒)
NODE_ENV或者ENV这两种写法,都不会随着打包命令的不用而被读取到,环境变量env文件里,能被读取到的变量必须是VUE_APP前缀开头的,这两种写法,纯粹是给码农自己看的而已。
所以当有多个环境,多个env文件时,不能单单在env文件里用NODE_ENV或者ENV这两种写法来区分不同环境。
三、解决方法
1、在env文件里新起VUE_APP_NODE_ENV(记得前缀是VUE_APP就行,标志位变量名随便起),项目都能根据命令不同,
正常读取到这个标志变量的值。也不用多安装一个cross-env,并且在package.json文件里进行配置
ps:个人感觉这种会方便一点,也比较直观,不会像我一样犯这种奇葩错误,以为在env里改了NODE_ENV就行就行。
2、安装cross-env
安装命令 npm install --save-dev cross-env
安装完之后,去到package.json里进行配置
默认配置是
根据需要自行修改即可
ps: 久违的更新,后续在掘金那边更新比较多吧。
作者:用户636430007170
链接:https://juejin.cn/post/7121543583319982087
来源:稀土掘金
著作权归作者所有。商业转载请联系作者获得授权,非商业转载请注明出处。
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 阿里巴巴 QwQ-32B真的超越了 DeepSeek R-1吗?
· 【译】Visual Studio 中新的强大生产力特性
· 10年+ .NET Coder 心语 ── 封装的思维:从隐藏、稳定开始理解其本质意义
· 【设计模式】告别冗长if-else语句:使用策略模式优化代码结构
· 字符编码:从基础到乱码解决