前端工程,yarn run start配合Jenkins腳本實(shí)現(xiàn)命令傳參

問題描述:

前端工程里,比較常見的會(huì)遇到,比如編譯的時(shí)候,需要分Release和Dev環(huán)境編譯,手工的話,以CRA為例子,可以在項(xiàng)目根目錄里定義.env文件,在run build之前手動(dòng)改.env文件內(nèi)容

/* .env */
REACT_APP_ENV=DEV
REACT_APP_LANGUAGE=en
REACT_APP_ROUTE_NAME=edu_loan

在項(xiàng)目里讀取可以是:

const env = process.env.REACT_APP_ENV;
console.log("env", env); // DEV

但是遇到j(luò)enkins自動(dòng)化部署,就不能這么來了,不然每次都要重新git push一下.env的變化,會(huì)很麻煩,怎么解決呢?

解決:

目光來到package.json

"scripts": {
    "start": "react-app-rewired start",
    "build": "react-app-rewired build",
  }

Jenkins腳本,走的也是yarn run build,那么新定義一個(gè)命令,命令傳參,覆蓋.env的值即可

在mac+linux下,

"scripts": {
    "start": "react-app-rewired start",
    "build": "react-app-rewired build",
    "build:release": "REACT_APP_ENV=RELEASE react-app-rewired build",
  }

而在win下

"scripts": {
    "start": "react-app-rewired start",
    "build": "react-app-rewired build",
    "win-build:release": "set REACT_APP_ENV=RELEASE&& react-app-rewired build",
  }

考慮團(tuán)隊(duì)開發(fā)者有可能用mac也可能用win,那么定義命令最終如下:

"scripts": {
    "start": "react-app-rewired start",
    "build": "react-app-rewired build",
    "build:release": "REACT_APP_ENV=RELEASE react-app-rewired build",
    "win-build:release": "set REACT_APP_ENV=RELEASE&& react-app-rewired build",
  }

在win下手動(dòng)打release包,用yarn run win-build:release命令,mac和linux下用yarn run build:release,而jenkins一般部署在服務(wù)器上,則一般使用yarn run build:release來進(jìn)行生產(chǎn)部署,而視要部署環(huán)境,部署腳本可以分別讓Jenkins執(zhí)行不同的命令,Perfect

?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
【社區(qū)內(nèi)容提示】社區(qū)部分內(nèi)容疑似由AI輔助生成,瀏覽時(shí)請(qǐng)結(jié)合常識(shí)與多方信息審慎甄別。
平臺(tái)聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點(diǎn),簡(jiǎn)書系信息發(fā)布平臺(tái),僅提供信息存儲(chǔ)服務(wù)。

相關(guān)閱讀更多精彩內(nèi)容

友情鏈接更多精彩內(nèi)容