vue ajax跨域提交,vue-cli开发时ajax跨域的方法
目的:使用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跨域的解決方法(推薦)就是小編分享給大家的全部內容了,希望能給大家一個參考,也希望大家多多支持碼農之家。
總結
以上是生活随笔為你收集整理的vue ajax跨域提交,vue-cli开发时ajax跨域的方法的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: 李笑来 css,李笑来都想投资千万美金的
- 下一篇: 旅途的开始