欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

詳解vue中使用axios對(duì)同一個(gè)接口連續(xù)請(qǐng)求導(dǎo)致返回?cái)?shù)據(jù)混亂的問(wèn)題

 更新時(shí)間:2019年11月06日 09:55:00   作者:小小小華  
這篇文章主要介紹了詳解vue中使用axios對(duì)同一個(gè)接口連續(xù)請(qǐng)求導(dǎo)致返回?cái)?shù)據(jù)混亂的問(wèn)題,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧

業(yè)務(wù)上出現(xiàn)一個(gè)問(wèn)題:如果連續(xù)對(duì)同一個(gè)接口發(fā)出請(qǐng)求,參數(shù)不同,有時(shí)候先請(qǐng)求的比后請(qǐng)求的返回?cái)?shù)據(jù)慢,導(dǎo)致數(shù)據(jù)順序混亂,或者數(shù)據(jù)被覆蓋的問(wèn)題,所以需要控制請(qǐng)求的順序。

解決方法:

1.直接跟后臺(tái)溝通,將所有參數(shù)放到數(shù)組里后臺(tái)統(tǒng)一接收并返回所有數(shù)據(jù)再由前端進(jìn)行數(shù)據(jù)的拆分使用。

2.對(duì)于出現(xiàn)返回的數(shù)據(jù)混亂問(wèn)題。

假設(shè)場(chǎng)景: 頁(yè)面中需要對(duì)三個(gè)部門請(qǐng)求對(duì)應(yīng)的部門人員,三個(gè)部門人員的數(shù)據(jù)為一個(gè)二維數(shù)組,連續(xù)發(fā)送請(qǐng)求,但由于返回?cái)?shù)據(jù)的順序不定,導(dǎo)致數(shù)組中的數(shù)據(jù)順序不是按照部門的順序。

解決方法:使用promise.all + axios。

//獲取部門人員的請(qǐng)求
getDepartPerson (departData) {
    let that = this
    return new Promise(function(resolve,reject) {
     that.$axios({
       method: 'get',
       url: ...,
       params: {
        ...
       }
      }).then(res => {
       const data = res.data.map(item => {
        return {
         value: item.userId,
         label: item.userName
        }
       })
       resolve(data)
      })
    })
    
   },
   
//使用promise.all控制返回的數(shù)據(jù)順序
setPersonData() {
    const data = [{
     departId: 1,
     departName: '部門1'
    }, {
     departId: 2,
     departName: '部門2'
    }, {
     departId: 3,
     departName: '部門3'
    }]
    let promise1 = this.getDepartPerson(data[0])
    let promise2 = this.getDepartPerson(data[1])
    let promise3 = this.getDepartPerson(data[2])
    console.log(promise1,promise2,promise3)
    let that = this
    Promise.all([promise1,promise2,promise3]).then(value => {
     console.log(value) //value返回的數(shù)據(jù)是按順序的
    })
   },
   

這里要注意

在promise中this不能指向vue的,所以在promise使用前賦值

let that = this

3.對(duì)于返回?cái)?shù)據(jù)出現(xiàn)覆蓋的問(wèn)題

假設(shè)場(chǎng)景:切換菜單的時(shí)候總是會(huì)向后臺(tái)發(fā)送同一個(gè)請(qǐng)求,不同參數(shù)。且假設(shè)這幾個(gè)菜單共用vuex中的一個(gè)state,假設(shè)從a菜單切換到b菜單中,a返回的數(shù)據(jù)比b返回的慢,導(dǎo)致覆蓋了state,此時(shí)雖然切換到b菜單,但是頁(yè)面上的數(shù)據(jù)是a的數(shù)據(jù)。

解決方法:使用axios中的CancelToken,對(duì)于之前的請(qǐng)求進(jìn)行禁止。

//取消接口相同參數(shù)不同的處于pending狀態(tài)下的請(qǐng)求
export const pending = []
let CancelToken = axios.CancelToken
let cancelPending = (config) => {
 for(let i=pending.length-1; i>=0; i--){
  if (!!config) {
   if (pending[i].u === config.url && pending[i].delPending) {
    console.log('delete request')
    pending[i].f() // 取消請(qǐng)求
    pending.splice(i, 1) // 移除當(dāng)前請(qǐng)求記錄
   }
  } else {
   pending[i].f() // 取消請(qǐng)求
   pending.splice(i, 1) // 移除當(dāng)前請(qǐng)求記錄
  }
 }
}

接著在請(qǐng)求前進(jìn)行攔截

/**
 * 請(qǐng)求前攔截
 */
export function requestSuccessFunc (config) {
 cancelPending(config)
 config.cancelToken = new CancelToken((c) => {
  pending.push({'u': config.url, 'f': c, delPending: config.delPending})
 })
 return config
}

/**
 * 請(qǐng)求結(jié)果預(yù)處理
 * @param response
 * @returns {Promise<never>}
 */
export function responseSuccessFunc (response) {
 cancelPending(response.config)
}

拓展:如果在切換路由的時(shí)候可以將之前頁(yè)面中請(qǐng)求處于pengding狀態(tài)的取消

export function routerAfterEachFunc () {
 // 這里可以做路由后操作
 //切換路由時(shí)取消之前頁(yè)面處于pending的請(qǐng)求
 for(let i=pending.length-1; i>=0; i--){
  pending[i].f() // 取消請(qǐng)求
  pending.splice(i, 1) // 移除當(dāng)前請(qǐng)求記錄
 }
 console.log(pending)
}

....

const ROUTER = new Router({
 routes: CONST_ROUTER
})
ROUTER.afterEach(routerAfterEachFunc)
export default ROUTER

4.假設(shè)這里不是請(qǐng)求同一個(gè)接口,而是上一個(gè)接口返回的數(shù)據(jù)作為下一個(gè)接口請(qǐng)求的參數(shù),這是可以使用async await

以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。

相關(guān)文章

最新評(píng)論