目的:使用vue-cli構建的項目,在開發時,想要訪問后臺接口獲取數據,這時就會出現跨域問題。
在config/index.js中進行如下配置
【即在進行ajax請求時,地址中任何以/api開頭的請求地址都被解析為目標地址,target就是你想要的后臺接口地址】
proxyTable: { ‘/api': { target: ‘https://188.188.18.8‘, changeOrigin: true, pathRewrite: { ‘^/api': ” } } }“`
vue-resource調用示例
this.$http.get('/api/v4/user/login', [options]).then(function(response){ // 響應成功回調}, function(response){ // 響應錯誤回調});
axios調用示例
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示例中 第一個參數為: /api/v4/user/login
就會被本地服務器自動解析為 https://188.188.18.8/v4/user/login 而這個正式我們需要的地址。
跨域原理(本地文件假裝在遠程服務器上):
通過瀏覽器打開頁面,當發起請求時:本地服務器的地址(通常是localhost:8080或者127.0.0.1:8080)會收到這個請求,接下來發現這個請求地址中含有字符串 /api,那么本地服務器會將請求地址變為 https://188.188.18.8/v4/ (配置地址) + user/login(調用方法處的詳細地址)。
同時本地服務器的地址會由localhost:8080 變為https://188.188.18.8/v4/,結果就是:
我們本地的文件會被認為是放在目標地址(https://188.188.18.8/v4/)服務器上的,當前服務器上的文件請求服務器其他東西,自然就不是跨域了。
以上這篇vue-cli開發時,關于ajax跨域的解決方法(推薦)就是小編分享給大家的全部內容了,希望能給大家一個參考,也希望大家多多支持武林網。
新聞熱點
疑難解答