背景
通常我們有一份webpack.dev.config.js使用webpack-dev-server的proxy,代理到開發服務器,來解決本地跨域問題。假如項目變大,可能需要proxy到不同環境,比如docker,或者后端開發人員的電腦上
現有問題
需求
假如本地開發服務器是dev.xxx.cn,docker環境是docker.xxx.cn,服務端開發人員ip是192.168.1.1
因為我本地用了gulp,啟動前端開發環境到命令是 gulp local
(與 npm run xx
的效果差不多),那么我希望
解決方案
創建webpack.local.js,proxy配置如下
proxy: { '/api/**': { target: 'http://{target|dev}.xxx.cn', changeOrigin: true, }, }
在我們運行 gulp local
時,讀取local.config文件,替換{target|dev}為 -t
后的內容,比如 gulp local -t docker
,替換后變為 'http://docker.xxx.cn'
再將替換后的文件內容輸出到一個名為webpack.local.target.js的文件里,然后執行 webpack-dev-server -c webpack.local.target.js
最后修改.gitignore文件,加入webpack.loc.target.js,這樣每次生成的文件就不會被誤push到遠程
實現細節
上面的配置中 {target|dev} |后面的dev是執行 gulp local 時的默認選項
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判斷內容為-t后的參數是否為ip,如果是,替換 'http://{target|dev}.xxx.cn' 為 http://192.168.1.1
第二個判斷是否有參數,如果有,替換為 http://docker.xxx.cn
第三個判斷就是直接運行 gulp local 不加 -t 時,替換為 http://dev.xxx.cn
正則不太懂可以看我另一篇文章《正則速記法》
覺得運行開發環境打包慢可以看《webpack性能榨汁機》
聲明:本網頁內容旨在傳播知識,若有侵權等問題請及時與本網聯系,我們將在第一時間刪除處理。TEL:177 7030 7066 E-MAIL:11247931@qq.com