目的:使用vue-cli構(gòu)建的項(xiàng)目,在開發(fā)時(shí),想要訪問后臺(tái)接口獲取數(shù)據(jù),這時(shí)就會(huì)出現(xiàn)跨域問題。
在config/index.js中進(jìn)行如下配置
【即在進(jìn)行ajax請(qǐng)求時(shí),地址中任何以/api開頭的請(qǐng)求地址都被解析為目標(biāo)地址,target就是你想要的后臺(tái)接口地址】
proxyTable: { ‘/api': { target: ‘https://188.188.18.8‘, changeOrigin: true, pathRewrite: { ‘^/api': ” } } }“`vue-resource調(diào)用示例
this.$http.get('/api/v4/user/login', [options]).then(function(response){ // 響應(yīng)成功回調(diào)}, function(response){ // 響應(yīng)錯(cuò)誤回調(diào)});axios調(diào)用示例
axios({ method: 'get', headers: {'Accept': '*/*'}, url: '/api/v4/user/login', data: options }) .then(function (response) { console.log(response.data) }) .catch(function (error) { console.log(error) })講解原理:
在配置中: target: ‘https://188.188.18.8'
在上方vue-resource示例中 第一個(gè)參數(shù)為: /api/v4/user/login
就會(huì)被本地服務(wù)器自動(dòng)解析為 https://188.188.18.8/v4/user/login 而這個(gè)正式我們需要的地址。
跨域原理(本地文件假裝在遠(yuǎn)程服務(wù)器上):
通過瀏覽器打開頁(yè)面,當(dāng)發(fā)起請(qǐng)求時(shí):本地服務(wù)器的地址(通常是localhost:8080或者127.0.0.1:8080)會(huì)收到這個(gè)請(qǐng)求,接下來發(fā)現(xiàn)這個(gè)請(qǐng)求地址中含有字符串 /api,那么本地服務(wù)器會(huì)將請(qǐng)求地址變?yōu)?https://188.188.18.8/v4/ (配置地址) + user/login(調(diào)用方法處的詳細(xì)地址)。
同時(shí)本地服務(wù)器的地址會(huì)由localhost:8080 變?yōu)閔ttps://188.188.18.8/v4/,結(jié)果就是:
我們本地的文件會(huì)被認(rèn)為是放在目標(biāo)地址(https://188.188.18.8/v4/)服務(wù)器上的,當(dāng)前服務(wù)器上的文件請(qǐng)求服務(wù)器其他東西,自然就不是跨域了。
以上這篇vue-cli開發(fā)時(shí),關(guān)于ajax跨域的解決方法(推薦)就是小編分享給大家的全部?jī)?nèi)容了,希望能給大家一個(gè)參考,也希望大家多多支持錯(cuò)新站長(zhǎng)站。
新聞熱點(diǎn)
疑難解答
圖片精選