亚洲激情专区-91九色丨porny丨老师-久久久久久久女国产乱让韩-国产精品午夜小视频观看

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

vue怎么實現重復點擊取消上一次請求封裝

發布時間:2022-11-11 10:03:06 來源:億速云 閱讀:151 作者:iii 欄目:開發技術

本篇內容主要講解“vue怎么實現重復點擊取消上一次請求封裝”,感興趣的朋友不妨來看看。本文介紹的方法操作簡單快捷,實用性強。下面就讓小編來帶大家學習“vue怎么實現重復點擊取消上一次請求封裝”吧!

使用場景

重復點擊或者多tab標簽使用一個視圖等(當然也可以用加載中或者透明背景禁止請求中再次點擊)

封裝代碼

來自于互聯網

let pending = []; //聲明一個數組用于存儲每個請求的取消函數和axios標識
let cancelToken = axios.CancelToken;
let removePending = (config) => {
 for(let p in pending){
  if(pending[p].u === config.url + '&' + config.method) { //當當前請求在數組中存在時執行函數體
   pending[p].f(); //執行取消操作
   pending.splice(p, 1); 
  }
 }
}

// http請求攔截器
axios.interceptors.request.use(config => {

 removePending(config); //在一個axios發送前執行一下取消操作
 config.cancelToken = new cancelToken((c)=>{
  // 這里的axios標識我是用請求地址&請求方式拼接的字符串,當然你可以選擇其他的一些方式
  pending.push({ u: config.url + '&' + config.method, f: c }); 
 });
 
 return Promise.resolve(config)
}, error => {
 return Promise.reject(error)
})

// http響應攔截器
axios.interceptors.response.use(data => { 
 
 removePending(data.config); //在一個axios響應后再執行一下取消操作,把已經完成的請求從pending中移除
 
 return Promise.resolve(data)
 
}, error => {
 //加載失敗
 return {'data':{}}
 // return Promise.reject(error)
})

經過多次測試發現不同請求也給我取消了,原因是沒有校驗請求參數,也就是說get請求可以用,修改以下代碼

pending.push({ u: config.url + '&' + config.method, f: c });

修改為:

pending.push({ u: config.url + JSON.stringify(config.data) +'&' + config.method, f: c });//config.data為請求參數

上面判斷也需要修改,這樣get請求和post都可以用了

vue是什么

Vue是一套用于構建用戶界面的漸進式JavaScript框架,Vue與其它大型框架的區別是,使用Vue可以自底向上逐層應用,其核心庫只關注視圖層,方便與第三方庫和項目整合,且使用Vue可以采用單文件組件和Vue生態系統支持的庫開發復雜的單頁應用。

到此,相信大家對“vue怎么實現重復點擊取消上一次請求封裝”有了更深的了解,不妨來實際操作一番吧!這里是億速云網站,更多相關內容可以進入相關頻道進行查詢,關注我們,繼續學習!

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

vue
AI

雷山县| 迁安市| 浦城县| 贵定县| 无棣县| 兴国县| 定西市| 合山市| 晋中市| 安龙县| 汉沽区| 禹州市| 志丹县| 海林市| 长寿区| 昌江| 大庆市| 竹山县| 三台县| 方山县| 临高县| 永康市| 夏邑县| 潮安县| 汝城县| 闵行区| 鄂伦春自治旗| 阜平县| 潞城市| 保定市| 昭通市| 宜城市| 股票| 龙门县| 寿阳县| 彭山县| 万荣县| 海南省| 灵台县| 宁晋县| 衢州市|