Add a host to your create-react-app app process.env via react-app-rewired when build
# use npm
$ npm install --save-dev react-app-rewire-host
# use yarn
$ yarn add --dev react-app-rewire-host
In the config-overrides.js
for react-app-rewired add code
/* config-overrides.js */
const createRewireHost = require('react-app-rewire-host');
module.exports = (config, env)=>{
// Also support object for config, like
// const hostConfig = {
// uat: {
// api: 'http://xxxuat.api.com',
// otherurl: 'http://xxxother.url.com',
// },
// pro: ...
// }
const hostConfig = {
uat: 'http://xxxuat.api.com',
pro: 'https://xxx.api.com'
}
const rewireHost = createRewireHost(hostConfig);
return rewireHost(config, env);
}
Then add a env HOST_NAME
when you build project in package.json
"scripts": {
- "build": "react-scripts build",
+ "build": "react-app-rewired HOST_NAME=pro build",
+ "build:uat": "react-app-rewired HOST_NAME=uat build",
}
Finally you can use process.env.REACT_APP_HOST
in your code and also the build dir will make a subdir that the name is HOST_NAME
.
MIT