日韩无码专区无码一级三级片|91人人爱网站中日韩无码电影|厨房大战丰满熟妇|AV高清无码在线免费观看|另类AV日韩少妇熟女|中文日本大黄一级黄色片|色情在线视频免费|亚洲成人特黄a片|黄片wwwav色图欧美|欧亚乱色一区二区三区

RELATEED CONSULTING
相關(guān)咨詢
選擇下列產(chǎn)品馬上在線溝通
服務時間:8:30-17:00
你可能遇到了下面的問題
關(guān)閉右側(cè)工具欄

新聞中心

這里有您想知道的互聯(lián)網(wǎng)營銷解決方案
前端快閃三:多環(huán)境靈活配置React

本文轉(zhuǎn)載自微信公眾號「精益碼農(nóng)」,作者有態(tài)度的馬甲。轉(zhuǎn)載本文請聯(lián)系精益碼農(nóng)公眾號。

網(wǎng)站建設哪家好,找創(chuàng)新互聯(lián)公司!專注于網(wǎng)頁設計、網(wǎng)站建設、微信開發(fā)、小程序設計、集團企業(yè)網(wǎng)站建設等服務項目。為回饋新老客戶創(chuàng)新互聯(lián)還提供了濱江免費建站歡迎大家使用!

你已經(jīng)使用Create React App[1] 腳手架搭建了React應用,現(xiàn)在該部署了。

一般會使用npm run build或者yarn build構(gòu)建出靜態(tài)資源, 由web服務器承載。

你會體驗到:多環(huán)境:test、staging、prod,他們都是獨立服務器、不同的主機名,需要打不同的包。

或者你會這樣手寫 if/else來配置不同環(huán)境的后端API基地址:

api-config.js

 
 
 
  1. let backendHost; 
  2. const apiVersion = 'v1'; 
  3.  
  4. const hostname = window && window.location && window.location.hostname; 
  5.  
  6. if(hostname === 'realsite.com') { 
  7.   backendHost = 'https://api.realsite.com'; 
  8. } else if(hostname === 'staging.realsite.com') { 
  9.   backendHost = 'https://staging.api.realsite.com'; 
  10. } else if(/^qa/.test(hostname)) { 
  11.   backendHost = `https://api.${hostname}`; 
  12. } else { 
  13.   backendHost = process.env.REACT_APP_BACKEND_HOST || 'http://localhost:8080'; 
  14.  
  15. export const API_ROOT = `${backendHost}/api/${apiVersion}`; 

然后在你的應用文件api.js, 導入這個配置:

 
 
 
  1. import {API_ROOT} from './api-config' 
  2. function getUsers() { 
  3.    return  fetch('${API_ROOT}/users') 
  4.       .then(res=> res.josn) 
  5.       .then(json=> json.data.users) 

終究不夠優(yōu)雅。

構(gòu)建時變量織入

要提醒的概念是:

環(huán)境變量是在構(gòu)建階段被織入,一旦完成構(gòu)建過程,構(gòu)建的產(chǎn)出物中變量值就被固定了(不論產(chǎn)出物被放置到哪個服務進程、哪個環(huán)境)。

畢竟React應用是作為靜態(tài)資源運行在瀏覽器上,而到了瀏覽器, 就no sense with環(huán)境變量。

Case1. 通過環(huán)境變量配置后端基地址

Create React APP腳手架創(chuàng)建了react應用,可通過全局的process.env來獲取環(huán)境變量。

1.process.env.NODE_ENV在構(gòu)建時被設置為production。

2. 還可以使用REACT_APP_開頭的環(huán)境變量來配置proces.env.

 
 
 
  1. REACT_APP_API_HOST= example.com yarn run build 
  2. # 將產(chǎn)生如下效果: 
  3. process.env.REACT_APP_API_HOST ="example.com" 
  4. process.env.NODE_ENV ="production" 

怎么設置環(huán)境變量?

windows: set/setx命令; linux: export命令,這里不贅述。

Case2 .env文件

臨時環(huán)境變量可以影響全局process.env的下級變量值, 但是不夠方便,Create React App支持使用.env文件來固定存儲環(huán)境變量值。

創(chuàng)建.env文件,內(nèi)容如下;

 
 
 
  1. REACT_APP_SPECIAL_FEATURE=true 
  2.  
  3. REACT_APP_API_HOST=default-host.com 

上面的環(huán)境變量打包后將會在development、test、production生效。

如果你要為不同環(huán)境設置變量,可放置.env.development、env.test、.env.production 文件。

再提醒一句:環(huán)境變量不僅可以用來配置后端基地址,還可以靈活的作為react app業(yè)務配置。


網(wǎng)頁名稱:前端快閃三:多環(huán)境靈活配置React
標題網(wǎng)址:http://www.5511xx.com/article/ccecjie.html