cross-env 根据环境打包

cross-env GitHub地址

React 环境变量

开发中请求后端接口时,会有一个公共的请求地址(服务器域名地址 === BASEURL)。
通常情况下,开发环境、线上环境的 BASEURL 接口地址是不一样的(开发环境服务器,uat服务器,生产服务器),所以不同环境打包时就需要切换到不同环境的服务器地址。(手动修改可以,但是太麻烦,而且容易忘记)所以,正确的写法应该是,根据不同的环境变量来自动确定不同的 BASEURL。

NODE_ENV 内置环境

create-react-app 创建项目时,内置的环境变量有三个,JavaScript代码中可以直接通过 process.env.NODE_ENV 来读取,无需引入。

三个环境变量依次对应三个运行命令:

npm start 时, NODE_ENV 的值为 development

npm run test 时, NODE_ENV 的值为 test

npm run build 时, NODE_ENV 的值为 production

如果你的环境只有 3 个,那内置环境足够,但是有时候我们需要的环境可能不止这几个。(尤其是,同一套应用给不同的用户去部署的时候,常见于外包项目)
那就需要我们自己来配置不同的环境。此时可以用到 cross-env 它的设计是为了定义全平台兼容的环境变量命令,因为 Windows 在设置环境变量的命令会出现阻塞问题

安装

npm install --save-dev cross-env

使用
{
  "scripts": {
    "build": "umi build",
    "build:tom": "cross-env HOST=tom umi build",
    "build:jerry": "cross-env HOST=jerry umi build",
  },
}

然后在需要用到的地方(比如:defaultSetting.js)进行判断即可:

let baseUrl = '';
let HOST = process.env.HOST;
if (HOST === 'tom') {
  baseUrl = '/www.tom.com/';
} else if (HOST === 'jerry') {
  baseUrl = '/www.jerry.com/';
} else {
  baseUrl = '/www.tomAndjerry.com/';
}

export default {
  baseUrl,
};

运行

运行 npm run build:tom 会得到 baseUrl = '/www.tom.com/'

运行 npm run build:jerry 会得到 baseUrl = '/www.jerry.com/'

最后的 else 其实是防备的 npm run buildnpm start 等不会设置这个变量的情况。

posted @ 2020-06-29 19:19  我的故事没编好  阅读(1237)  评论(0编辑  收藏  举报