解決vue跨域axios異步通信問題
在項目中,常常需要從后端獲取數(shù)據(jù)內(nèi)容。特別是在前后端分離的時候,前端進行了工程化部署,跨域請求成了一個前端必備的技能點。好在解決方案很多。
在vue中,在開發(fā)中,當前使用較多的是axios進行跨域請求數(shù)據(jù),但不少人遇到如下問題:
•異步通信,無法同步執(zhí)行
•無法集中管理
•不便閱讀
•還未請求成功就調(diào)轉(zhuǎn)了
•then里面的邏輯越來越繁雜
以往的網(wǎng)絡(luò)請求的寫法如下:
// main.js
// 引入axios
import axios from 'axios'
Vue.prototype.$axios = axios;
// vue頁面中的使用
// get
let url = '地址'
this.$axios.get(url,{
params:{} // 參數(shù)信息
})
.then((res) => {
// 成功后執(zhí)行語句
})
.catch((err) =>{
// 網(wǎng)絡(luò)中斷或失敗執(zhí)行語句
})
// post
let url = '地址'
this.$axios.post(url,{
// 參數(shù)信息
})
.then((res) => {
// 成功后執(zhí)行語句
})
.catch((err) =>{
// 網(wǎng)絡(luò)中斷或失敗執(zhí)行語句
})
或許在目前的過程中異步能夠更好的解決用戶體驗感,先加載后彈出。但總有那么一個場景我們需要大量的內(nèi)容進行處理,而且前后有明顯的順序執(zhí)行的關(guān)系,那么異步通信可能會對你造成不必要的問題。所以,解決運用async/await解決異步通信問題
在main.js旁邊新建http.js文件
// http.js
引入axios
import axios from 'axios'
var http = {
// get 請求
get: function(url,params){
return new Promise((resolve,reject) => {
axios.get(url,{
params:params
})
.then((response) =>{
resolve(response.data)
})
.catch((error) => {
reject( error )
})
})
}
// post 請求
post: function(url,params){
return new Promise((resolve,reject) => {
axios.post(url,params)
.then((response) => {
resolve( response.data )
})
.catch((error) => {
reject( error )
})
})
}
}
export default http
并在main.js入口引入
// 引入http請求 import http from './http.js' Vue.prototype.$http = http
現(xiàn)在就可以在頁面中使用了
// 在vue中使用
// get
async login () {
let url = '地址'
let params = {} // 參數(shù)
let res = await this.$http.get(url,params)
}
// post
async login () {
let url = '地址'
let params = {} // 參數(shù)
let res = await this.$http.post(url,params)
}
async 放在方法前面
await 放在$http前面就OK了
單詞示意:
async:異步。
await:等待。
總結(jié)
以上所述是小編給大家介紹的解決vue跨域axios異步通信問題,希望對大家有所幫助,如果大家有任何疑問請給我留言,小編會及時回復大家的。在此也非常感謝大家對腳本之家網(wǎng)站的支持!
如果你覺得本文對你有幫助,歡迎轉(zhuǎn)載,煩請注明出處,謝謝!
相關(guān)文章
vue+el-upload實現(xiàn)多文件動態(tài)上傳
這篇文章主要為大家詳細介紹了vue+el-upload實現(xiàn)多文件動態(tài)上傳,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下2021-10-10
Vue3如何解決路由緩存問題(響應路由參數(shù)的變化)
這篇文章主要介紹了Vue3如何解決路由緩存問題(響應路由參數(shù)的變化),具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教2024-03-03
淺析Visual Studio Code斷點調(diào)試Vue
本篇文章給大家總結(jié)了Visual Studio Code斷點調(diào)試Vue的方法以及心得分享,需要的朋友參考學習下。2018-02-02
解決iview多表頭動態(tài)更改列元素發(fā)生的錯誤的方法
這篇文章主要介紹了解決iview多表頭動態(tài)更改列元素發(fā)生的錯誤的方法,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧2018-11-11
Vue3+Vite 環(huán)境變量和模式配置詳解(推薦)
在Vue 3中,你可以通過 import.meta.env 訪問環(huán)境變量,這些變量可以在你的應用代碼中使用,但它們通常用于配置不應該硬編碼在代碼中的值,這篇文章主要介紹了Vue3+Vite 環(huán)境變量和模式配置詳解,需要的朋友可以參考下2024-12-12
element ui的el-input-number修改數(shù)值失效的問題及解決
這篇文章主要介紹了element ui的el-input-number修改數(shù)值失效的問題及解決方案,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教2022-05-05

