這篇文章將為大家詳細講解有關(guān)怎么解決webpack-dev-server代理常切換問題,小編覺得挺實用的,因此分享給大家做個參考,希望大家閱讀完這篇文章后可以有所收獲。
我們一直強調(diào)成都做網(wǎng)站、成都網(wǎng)站建設(shè)對于企業(yè)的重要性,如果您也覺得重要,那么就需要我們慎重對待,選擇一個安全靠譜的網(wǎng)站建設(shè)公司,企業(yè)網(wǎng)站我們建議是要么不做,要么就做好,讓網(wǎng)站能真正成為企業(yè)發(fā)展過程中的有力推手。專業(yè)網(wǎng)絡(luò)公司不一定是大公司,創(chuàng)新互聯(lián)作為專業(yè)的網(wǎng)絡(luò)公司選擇我們就是放心。
背景
通常我們有一份webpack.dev.config.js使用webpack-dev-server的proxy,代理到開發(fā)服務(wù)器,來解決本地跨域問題。假如項目變大,可能需要proxy到不同環(huán)境,比如docker,或者后端開發(fā)人員的電腦上
現(xiàn)有問題
需要手動更改proxy配置,比較麻煩還容易寫錯
改變后的config文件會被git檢測到
不小心將本地修改的配置push到遠程倉庫,對其他人造成困擾
需求
假如本地開發(fā)服務(wù)器是dev.xxx.cn,docker環(huán)境是docker.xxx.cn,服務(wù)端開發(fā)人員ip是192.168.1.1
因為我本地用了gulp,啟動前端開發(fā)環(huán)境到命令是 gulp local
(與 npm run xx
的效果差不多),那么我希望
當(dāng)gulp local的時候,proxy 為 dev.xxx.cn
當(dāng)gulp local -t docker的時候,proxy 為 docker.xxx.cn
當(dāng)gulp local -t 192.168.1.1的時候,proxy 為 192.168.1.1
解決方案
創(chuàng)建webpack.local.js,proxy配置如下
proxy: { '/api/**': { target: 'http://{target|dev}.xxx.cn', changeOrigin: true, }, }
在我們運行 gulp local
時,讀取local.config文件,替換{target|dev}為 -t
后的內(nèi)容,比如 gulp local -t docker
,替換后變?yōu)?'http://docker.xxx.cn'
再將替換后的文件內(nèi)容輸出到一個名為webpack.local.target.js的文件里,然后執(zhí)行 webpack-dev-server -c webpack.local.target.js
最后修改.gitignore文件,加入webpack.loc.target.js,這樣每次生成的文件就不會被誤push到遠程
實現(xiàn)細節(jié)
上面的配置中 {target|dev} |后面的dev是執(zhí)行 gulp local 時的默認(rèn)選項
const { t } = gulputil.env let config = fs.readFileSync(_path.join(__dirname, '/webpack.loc.js')).toString() if (/\d{1,3}(\.\d{1,3}){3}/.test(t)) { config = config.replace(/\\{target[^}]+\\}[^']*/g, t) } else if (typeof t === 'string' && t.length > 0) { config = config.replace(/\\{target[^}]+\\}/g, t) } else { config = config.replace(/\\{target\\|([^}]+)\\}/g, '$1') } fs.writeFileSync(_path.join(__dirname, '/webpack.loc.target.js'), config)
第一個if判斷內(nèi)容為-t后的參數(shù)是否為ip,如果是,替換 'http://{target|dev}.xxx.cn' 為 http://192.168.1.1
第二個判斷是否有參數(shù),如果有,替換為 http://docker.xxx.cn
第三個判斷就是直接運行 gulp local 不加 -t 時,替換為 http://dev.xxx.cn
關(guān)于“怎么解決webpack-dev-server代理常切換問題”這篇文章就分享到這里了,希望以上內(nèi)容可以對大家有一定的幫助,使各位可以學(xué)到更多知識,如果覺得文章不錯,請把它分享出去讓更多的人看到。