前端快闪三:多环境灵活配置react
大前端快閃:package.json文件知多少?
大前端快閃二:react開發模式 一鍵啟動多個服務
? ? ? ? 你已經使用Create React App[1]?腳手架搭建了React應用,現在該部署了。
一般會使用npm run build或者yarn build構建出靜態資源, 由web服務器承載。
你會體驗到:多環境:test、staging、prod,他們都是獨立服務器、不同的主機名,需要打不同的包。
或者你會這樣手寫 if/else來配置不同環境的后端API基地址:
api-config.js
let?backendHost; const?apiVersion?=?'v1';const?hostname?=?window?&&?window.location?&&?window.location.hostname;if(hostname?===?'realsite.com')?{backendHost?=?'https://api.realsite.com'; }?else?if(hostname?===?'staging.realsite.com')?{backendHost?=?'https://staging.api.realsite.com'; }?else?if(/^qa/.test(hostname))?{backendHost?=?`https://api.${hostname}`; }?else?{backendHost?=?process.env.REACT_APP_BACKEND_HOST?||?'http://localhost:8080'; }export?const?API_ROOT?=?`${backendHost}/api/${apiVersion}`;然后在你的應用文件api.js, 導入這個配置
import?{API_ROOT}?from?'./api-config' function?getUsers()?{return??fetch('${API_ROOT}/users').then(res=>?res.josn).then(json=>?json.data.users) }終究不夠優雅。
快閃三:react工程化:通過環境變量靈活配置react
構建時變量織入
要提醒的概念是:
環境變量是在構建階段被織入,一旦完成構建過程,構建的產出物中變量值就被固定了(不論產出物被放置到哪個服務進程、哪個環境)。
畢竟React應用是作為靜態資源運行在瀏覽器上,而到了瀏覽器, 就no sense with環境變量。
Case1. 通過環境變量配置后端基地址
Create React APP腳手架創建了react應用,可通過全局的process.env來獲取環境變量。
1.process.env.NODE_ENV在構建時被設置為production。2.?還可以使用REACT_APP_開頭的環境變量來配置proces.env.
故
REACT_APP_API_HOST=?example.com?yarn?run?build #?將產生如下效果: process.env.REACT_APP_API_HOST?="example.com" process.env.NODE_ENV?="production"怎么設置環境變量?
windows: set/setx命令; linux: export命令,這里不贅述。
Case2 .env文件
臨時環境變量可以影響全局process.env的下級變量值, 但是不夠方便,Create React App支持使用.env文件來固定存儲環境變量值。
創建.env文件,內容如下;
REACT_APP_SPECIAL_FEATURE=true REACT_APP_API_HOST=default-host.com上面的環境變量打包后將會在development、test、production生效。??
如果你要為不同環境設置變量,可放置.env.development、env.test、.env.production 文件。
再提醒一句:環境變量不僅可以用來配置后端基地址,還可以靈活的作為react app業務配置。
?性感豹紋
?鵝廠二面,Nginx回憶錄
?前后端分離,如何在前端項目中動態插入后端API基地址?(in docker)
?前端鏡像打包這么慢,你該反省一下
?誰說docker-compose不能水平擴展容器、服務多實例?
?面試官:單點登錄你搞過嗎?
?難纏的布隆過濾器,這次終于通透了
引用鏈接
[1]?Create React App:?https://github.com/facebook/create-react-app
總結
以上是生活随笔為你收集整理的前端快闪三:多环境灵活配置react的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: .Net微服务实战之可观测性
- 下一篇: C#Socket通信