Vue在/public目录下访问process.env.NODE_ENV(其它通用)

总所周知,/public目录下的js文件是不会经过webpack处理的.

所以process.env.NODE_ENV 也无效.无法判断,当要根据这个去判断的时候就麻烦了. 但有个办法可以解决这个问题.

先安装 npm install --save-dev cross-env

就是在index.html里面去赋值到window变量中,如下

在 /public/index.html中加上

javascript 复制代码
 <script>
      window.VUE_APP_NODE_ENV = '<%= process.env.NODE_ENV %>';
    </script>

然后在/public下的js文件中就可以判断了

复制代码
 if(VUE_APP_NODE_ENV === 'dproduction'){ }

然后在 package.json中标记

复制代码
    "devtest": "cross-env NODE_ENV=dtest vue-cli-service serve",

上面的判断就跟赋值就会生效.

相关推荐
前端一课15 小时前
解释watch和computed的原理
前端·面试
前端一课15 小时前
【vue高频面试题】第 18 题:Vue3 响应式原理中的 effect、依赖收集与依赖触发
前端·面试
前端一课15 小时前
【vue高频面试题】第 19 题:Vue3 性能优化技巧
前端·面试
前端一课15 小时前
【vue高频面试题】第 15 题:computed vs watch 区别 + 使用场景
前端·面试
前端一课15 小时前
【vue高频面试题】第 20 题:Vue3 生命周期 + watch 执行顺序
前端·面试
前端一课15 小时前
【vue高频面试题】第 16 题:Vue3 响应式原理深度解析(Proxy + effect 栈 + 依赖追踪)
前端·面试
执笔论英雄15 小时前
【大模型推理】小白教程:vllm 异步接口
前端·数据库·python
炒毛豆15 小时前
vue3+ant design vue实现表单验证失败后,自动滚动到失败的位置(scrollToField)
前端·javascript·vue.js
l***775215 小时前
Vue项目中 安装及使用Sass(scss)
vue.js·sass·scss
木易 士心15 小时前
Error: Module ‘@npmcli/config’ not found — 如何解决?
javascript·npm