詳解Vue-cli代理解決跨域問題
使用vue-cli調(diào)接口的時候,總是會出現(xiàn)垮與問題,因為vue的localhost與訪問域名不一致導(dǎo)致。而這一點,開發(fā)者顯然也想到了,故而在vuejs-templates,也就是vue-cli的使用的模板插件里,有關(guān)于API proxy的說明,這個配置就是將localhost映射成訪問的域名。
那么何為代理?
代理服務(wù)器英文全稱是Proxy Server,其功能就是代理網(wǎng)絡(luò)用戶去取得網(wǎng)絡(luò)信息。形象的說:它是網(wǎng)絡(luò)信息的中轉(zhuǎn)站??梢院唵未直├斫鉃榘涯愕挠蛎D(zhuǎn)換成你訪問的域名,(我這么記的,當(dāng)然可能并不恰當(dāng))形成同源,就能訪問。
那么在vue里,如何設(shè)置代理?
1.config目錄找到index.js
2.在dev里添加proxyTable
dev: { env: require('./dev.env'), port: 8080, autoOpenBrowser: true, assetsSubDirectory: 'static', assetsPublicPath: '/', proxyTable: { '/api':{ target:"http://47.93.166.112/BrainPcWeb",//設(shè)置你調(diào)用的接口域名和端口號 別忘了加http changeOrigin:true, pathRewrite:{ '^/api':''//這里理解成用‘/api'代替target里面的地址,后面組件中我們掉接口時直接用api代替 //比如我要調(diào)用'http://40.00.100.133:3002/user/login',直接寫‘/api/user/login'即可 } } }
這一步為止,你重新run一下vue已經(jīng)不存在跨域問題了。
如果你想在main.js把api定義成全局變量也可以這樣,雖然多此一舉。代碼如下:
Vue.prototype.HOST = '/api' //這時,你的/api/user/login就可以換成this.HOST/user/login
但是注意了
這只是開發(fā)環(huán)境(dev)中解決了跨域問題,生產(chǎn)環(huán)境中真正部署到服務(wù)器上如果是非同源還是存在跨域問題
部署到服務(wù)器上跨域解決問題,以后項目布置會繼續(xù)更新。
以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
相關(guān)文章
vue3使用xgPalyer實現(xiàn)截圖功能的方法詳解
這篇文章主要為大家詳細介紹了如何在vue3中使用xgPalyer截圖功能,以及自定義插件,文中的示例代碼講解詳細,感興趣的小伙伴可以跟隨小編一起學(xué)習(xí)一下2024-02-02VUE3自定義指令防止重復(fù)點擊多次提交的實現(xiàn)方法
vue3項目,新增彈框連續(xù)點擊確定按鈕防止多次提交,在按鈕上添加自定義指令,這篇文章主要介紹了VUE3自定義指令防止重復(fù)點擊多次提交的實現(xiàn)方法,需要的朋友可以參考下2024-08-08淺析vue偵測數(shù)據(jù)的變化之基本實現(xiàn)
這里涉及到Vue一個重要特性:響應(yīng)式系統(tǒng)。數(shù)據(jù)模型只是普通的 JavaScript對象,當(dāng)我們修改時,視圖會被更新,而變化偵測是響應(yīng)式系統(tǒng)的核心2021-06-06