成人免费xxxxx在线视频软件_久久精品久久久_亚洲国产精品久久久_天天色天天色_亚洲人成一区_欧美一级欧美三级在线观看

前端快閃三:多環境靈活配置React

開發 前端
一般會使用npm run build或者yarn build構建出靜態資源, 由web服務器承載。你會體驗到:多環境:test、staging、prod,他們都是獨立服務器、不同的主機名,需要打不同的包。

[[426688]]

本文轉載自微信公眾號「精益碼農」,作者有態度的馬甲。轉載本文請聯系精益碼農公眾號。

你已經使用Create React App[1] 腳手架搭建了React應用,現在該部署了。

一般會使用npm run build或者yarn build構建出靜態資源, 由web服務器承載。

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

[[426689]]

或者你會這樣手寫 if/else來配置不同環境的后端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) 

終究不夠優雅。

構建時變量織入

要提醒的概念是:

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

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

Case1. 通過環境變量配置后端基地址

Create React APP腳手架創建了react應用,可通過全局的process.env來獲取環境變量。

1.process.env.NODE_ENV在構建時被設置為production。

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

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

怎么設置環境變量?

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

Case2 .env文件

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

創建.env文件,內容如下;

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

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

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

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

 

責任編輯:武曉燕 來源: 精益碼農
相關推薦

2023-04-12 07:55:24

Web前端工程化

2021-09-27 06:29:02

React開發模式

2015-02-11 10:21:07

JavaScript

2021-09-26 06:43:08

快閃前端文件

2010-08-06 10:30:53

配置VLANHyper-V

2018-11-08 23:09:20

零售快閃店轉型

2010-08-06 10:36:54

VLAN配置Hyper-V

2022-02-16 19:42:25

Spring配置開發

2022-08-05 08:17:39

數據庫隔離域名

2020-11-05 10:40:07

Spring Boot多模塊Java

2019-01-16 09:40:16

微信多閃馬桶

2013-06-28 09:35:04

Hypervisor虛擬化成本

2019-08-12 09:36:49

2019-11-19 15:36:42

JavaJava升級編程語言

2020-03-09 10:09:18

混合云云計算

2025-01-14 08:40:00

VueReactAngular

2012-05-10 09:15:47

2012-05-10 10:00:43

2017-09-11 14:35:34

編輯器開發環境React

2022-10-10 18:39:01

legendapp前端框架
點贊
收藏

51CTO技術棧公眾號

主站蜘蛛池模板: 天天干天天操天天爽 | 中文字幕av色 | 新疆少妇videos高潮 | 成人免费视频网站在线看 | 免费看黄色国产 | 色眯眯视频在线观看 | 久久伊人精品 | 久久国产精品视频 | 狠狠色香婷婷久久亚洲精品 | 365夜爽爽欧美性午夜免费视频 | 99久久精品一区二区毛片吞精 | 欧美极品一区二区 | 欧美一区二区免费电影 | 久久首页| 鸳鸯谱在线观看高清 | 中文字幕在线一区二区三区 | 亚洲免费在线观看视频 | 精品96久久久久久中文字幕无 | 国产成人99久久亚洲综合精品 | 精品久| 免费视频一区 | 欧美成人手机在线 | 91久久国产精品 | 一色桃子av一区二区 | 欧美激情一区二区三区 | 欧洲成人| 中国一级特黄视频 | 网色 | 四虎海外 | 亚洲精品成人av | 91久久精品国产 | 久久久精品一区 | 91超碰在线观看 | 国产精品毛片av一区 | 亚洲天堂影院 | 亚洲欧美日韩国产综合 | 色综合天天综合网国产成人网 | 亚洲欧美日韩在线 | 成人在线免费观看 | 国产目拍亚洲精品99久久精品 | 国产精品乱码一区二区三区 |