zoukankan      html  css  js  c++  java
  • vue-cli配置环境变量的方法

    在实际项目开发中,经常会碰到需要判断环境变量的情景。

      vue-cli  的环境下,已经默认配置了一个NODE_ENV的环境变量。当 npm run dev 时,环境变量是development ;当 npm run build 时,环境变量是production。

    用过vue-cli开发的通常对NODE_ENV都不陌生,比如我们配置ajax请求的域名头时,就是通过判断 process.env.NODE_ENV来实现的。

    if (process.env.NODE_ENV === 'production') {
     axios.defaults.baseURL = 'http://customer.medsci.cn'
    }

    项目中通常会有测试服务器环境正式服务器环境之分,前端请求接口的域名也得区分。我们通过proces.env.NODE_ENV区分环境变量(proces.env.NODE_ENV是一个能够全局访问的参数),可以处理那些需要根据环境变量来做不同操作的问题。

    上面的process.env.NODE_ENV是vue-cli默认配置的,但是在实际项目开发中,只有开发环境和生产环境是还不够。比如我们还想来一个测试坏境,这时候就需要自己定义了。

    实现步骤:

    1、安装cross-env

    npm install cross-env --save-dev

    2、vue-cli的配置本质就是webpack的配置。当我们运行 npm run dev 的时候,其实执行的是package.json中的 scripts 的 dev ,即 build/dev-server.js , 执行这里面一系列的配置启动整个服务。

    增加一个环境变量,在dev下加一个 devtest 命令:

    "devtest": "cross-env TESTING=true node build/dev-server.js",

    这样就可以通过 npm run devtest  也能启动整个服务了。

    注意上面的命令,我们加了一个TESTING=true,这个就是加入的环境变量TESTING:true。通过上面的devtest的配置,我们就可以运行 npm run devtest 像 npm run dev 那样运行起来整个程序。

    不过发现,此时在项目中我们获取不到 process.env.TESTING 这个变量,这是为什么呢?如果是直接用webpack是可以的,经过查看,是在vue-cli的一系列配置文件中,已经写死了这些,因此需要改动加上。

    在根目录 config下,有 dev.env.js 和 prod.env.js ,这两个文件就是关键了,我们在NODE_ENV下面加一行 TESTING:process.env.TESTING

    module.exports = {
     NODE_ENV: '"production"',
     TESTING: process.env.TESTING
    }

    这时我们就能全局访问 process.env.TESTING 变量了。

     npm run dev 的时候,TESTING是undefined;当 npm run devtest 的时候,TESTING是true。

    同理,我们可以添加一个 npm run test 命令, 与 npm run build 命令对应,加入打包测试的环境变量。

     

  • 相关阅读:
    博客园作业 04
    C语言II博客作业02
    C语言II博客作业01
    linux找不到动态链接库.so文件的解决方法
    工厂模式
    markdown基本语法
    IDEA解决file://无法访问问题,构建虚拟路径方法
    python 制作伪switch(不过认为更加麻烦,使用起来不方便,不如跟随python使用if更轻巧)
    python 读取编码为UTF-8-BOM文件(如果一直出现读取失败,可以尝试用记事本查看文件的编码格式,且可以读取任何文件格式)
    python 读取excel方法(最大行数:1048576)
  • 原文地址:https://www.cnblogs.com/janney/p/11322184.html
Copyright © 2011-2022 走看看