vue配置文件實現(xiàn)代理v2版本的方法
vue實現(xiàn)不同服務(wù)器代理,接上篇,雖然可實現(xiàn)多版本代理,但是每增加一種模式就需要重下新修改vue.config.js以及.env.dev.local,感覺很不智能,擴(kuò)展性挺差。
主要實現(xiàn)思路:
模仿vue中.env.local文件,此文件被git忽略,且可根據(jù)當(dāng)前環(huán)境變量加載不同的數(shù)據(jù),由此在項目根目錄下新建development文件夾,在development文件加下建立config文件夾,用戶放置配置文件,config下目前暫有兩個文件 config.development.local config.owndev.local
在.gitignore中添加
development/config/config.local
development/config/config.*.local
忽略所有的配置local文件,然后通過node讀取文件加載配置的json文件,并將代理規(guī)則通過代碼完善,導(dǎo)出代理規(guī)則,最終輸出的vue.config.js中實現(xiàn)代理,通過cross-env模塊改變系統(tǒng)變量設(shè)置,最終實現(xiàn)不同環(huán)境下不同文件的加載
現(xiàn)新建項目,目錄結(jié)構(gòu)如下:
其中development為新添加目錄,其中主要放置需要代理的文件
config下
.gitignore 添加對文件的忽略
development/config/config.local development/config/config.*.local development/config 下的config.development.dev { "/api":"http://serverurl" } development/config 下的config.owndev.dev { "/api/login":"http://localhost:8080", "/api/register":"http://localhost:8081" }
proxy.js實現(xiàn)主要的代理邏輯,思路如下,根據(jù)cross-env設(shè)置的環(huán)境變量加載不同的json文件
cross-env 用法,在package.json
中devDependencies
中添加 ,然后npm i --save-dev cross-env
即可
"devDependencies": { "cross-env": "^5.2.0" }
用法 在啟動vue服務(wù)前添加 cross-env BUILD_ENV=development
即可
如下
"script":{ "serve": "cross-env BUILD_ENV=development vue-cli-service serve", "owndev": "cross-env BUILD_ENV=owndev vue-cli-service serve", }
當(dāng)執(zhí)行npm run serve
時 process.env.BUILD_ENV
值為development,當(dāng)執(zhí)行 npm run owndev
時,process.env.BUILD_ENV的值為 owndev
proxy.js實現(xiàn)的主邏輯如下:
var path = require('path'); //系統(tǒng)路徑模塊 var fs = require('fs'); //文件模塊 const defaultProxy = { "/api":"http://serverUrl" }; //根據(jù)當(dāng)前的運行環(huán)境判斷走哪個配置 const DEVELOPMENT = "development" let currentEnv = process.env.BUILD_ENV?process.env.BUILD_ENV:DEVELOPMENT let configPath = `config/config.${currentEnv}.local` let filePath = path.join(__dirname, configPath); //文件路徑,__dirname為當(dāng)前運行js文件的目錄 let proxyContent = null; //讀取json文件,異步 /*fs.readFile(filePath, 'utf-8', function(err, data) { if (!err) { proxyContent = data; } });*/ //將json字符串轉(zhuǎn)化為json對象 try{ proxyContent = JSON.parse(fs.readFileSync(filePath,'utf-8')) }catch(e){ proxyContent = defaultProxy } if(proxyContent == null){ proxyContent = defaultProxy } let proxys = {} //遍歷所有的配置代理,對應(yīng)不同的服務(wù)器 Object.getOwnPropertyNames(proxyContent).forEach(function (key) { let targetPath = proxyContent[key] let proxyItem = {}; proxyItem.target = targetPath; proxyItem.ws = true; proxyItem.changeOrigin = true; proxyItem.pathRewrite = {} proxyItem.pathRewrite[`^${key}`] = '/' proxys[key] = proxyItem }); module.exports = proxys
在vue.config.js中引用該文件
let proxy = require('./development/proxy/proxy') let config = { publicPath:"/" , devServer: { port: 8080, proxy:proxy } } module.exports = config
以上,完成。使用時只需更改 development/config/config.owndev.local
文件即可,即使增加了代理也可只增加配置文件完成代理。
總結(jié)
以上所述是小編給大家介紹的vue配置文件實現(xiàn)代理v2版本的方法,希望對大家有所幫助,如果大家有任何疑問請給我留言,小編會及時回復(fù)大家的。在此也非常感謝大家對腳本之家網(wǎng)站的支持!
如果你覺得本文對你有幫助,歡迎轉(zhuǎn)載,煩請注明出處,謝謝!
相關(guān)文章
vue element 中的table動態(tài)渲染實現(xiàn)(動態(tài)表頭)
這篇文章主要介紹了vue element 中的table動態(tài)渲染實現(xiàn)(動態(tài)表頭),文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2019-11-11關(guān)于vue組件的更新機(jī)制?resize()?callResize()
這篇文章主要介紹了關(guān)于vue組件的更新機(jī)制?resize()?callResize(),具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教2022-04-04Vue實現(xiàn)Base64轉(zhuǎn)png、jpg圖片格式
這篇文章主要給大家介紹了關(guān)于Vue實現(xiàn)Base64轉(zhuǎn)png、jpg圖片格式的相關(guān)資料,前段獲取生成的是base64圖片,需要轉(zhuǎn)化為jpg,png,需要的朋友可以參考下2023-09-09