詳解Vue-cli代理解決跨域問題
使用vue-cli調(diào)接口的時(shí)候,總是會(huì)出現(xiàn)垮與問題,因?yàn)関ue的localhost與訪問域名不一致導(dǎo)致。而這一點(diǎn),開發(fā)者顯然也想到了,故而在vuejs-templates,也就是vue-cli的使用的模板插件里,有關(guān)于API proxy的說明,這個(gè)配置就是將localhost映射成訪問的域名。
那么何為代理?
代理服務(wù)器英文全稱是Proxy Server,其功能就是代理網(wǎng)絡(luò)用戶去取得網(wǎng)絡(luò)信息。形象的說:它是網(wǎng)絡(luò)信息的中轉(zhuǎn)站。可以簡(jiǎn)單粗暴理解為把你的域名轉(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)用的接口域名和端口號(hào) 別忘了加http
changeOrigin:true,
pathRewrite:{
'^/api':''//這里理解成用‘/api'代替target里面的地址,后面組件中我們掉接口時(shí)直接用api代替
//比如我要調(diào)用'http://40.00.100.133:3002/user/login',直接寫‘/api/user/login'即可
}
}
}
這一步為止,你重新run一下vue已經(jīng)不存在跨域問題了。
如果你想在main.js把a(bǔ)pi定義成全局變量也可以這樣,雖然多此一舉。代碼如下:
Vue.prototype.HOST = '/api' //這時(shí),你的/api/user/login就可以換成this.HOST/user/login
但是注意了
這只是開發(fā)環(huán)境(dev)中解決了跨域問題,生產(chǎn)環(huán)境中真正部署到服務(wù)器上如果是非同源還是存在跨域問題
部署到服務(wù)器上跨域解決問題,以后項(xiàng)目布置會(huì)繼續(xù)更新。
以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
相關(guān)文章
vue實(shí)現(xiàn)表格數(shù)據(jù)的增刪改查
這篇文章主要為大家詳細(xì)介紹了vue實(shí)現(xiàn)表格數(shù)據(jù)的增刪改查,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2017-07-07
vue3使用xgPalyer實(shí)現(xiàn)截圖功能的方法詳解
這篇文章主要為大家詳細(xì)介紹了如何在vue3中使用xgPalyer截圖功能,以及自定義插件,文中的示例代碼講解詳細(xì),感興趣的小伙伴可以跟隨小編一起學(xué)習(xí)一下2024-02-02
VUE3自定義指令防止重復(fù)點(diǎn)擊多次提交的實(shí)現(xiàn)方法
vue3項(xiàng)目,新增彈框連續(xù)點(diǎn)擊確定按鈕防止多次提交,在按鈕上添加自定義指令,這篇文章主要介紹了VUE3自定義指令防止重復(fù)點(diǎn)擊多次提交的實(shí)現(xiàn)方法,需要的朋友可以參考下2024-08-08
淺析vue偵測(cè)數(shù)據(jù)的變化之基本實(shí)現(xiàn)
這里涉及到Vue一個(gè)重要特性:響應(yīng)式系統(tǒng)。數(shù)據(jù)模型只是普通的 JavaScript對(duì)象,當(dāng)我們修改時(shí),視圖會(huì)被更新,而變化偵測(cè)是響應(yīng)式系統(tǒng)的核心2021-06-06
vue中ref引用操作DOM元素的實(shí)現(xiàn)
本文主要介紹了vue中ref引用操作DOM元素的實(shí)現(xiàn),文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2023-01-01

