中文字幕av专区_日韩电影在线播放_精品国产精品久久一区免费式_av在线免费观看网站

溫馨提示×

溫馨提示×

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

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

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

莱芜市| 周宁县| 泸水县| 永登县| 平阴县| 咸阳市| 临邑县| 崇明县| 托里县| 兴义市| 年辖:市辖区| 鲁甸县| 新田县| 惠安县| 稷山县| 砚山县| 德清县| 平果县| 大厂| 铁力市| 天峨县| 桓仁| 外汇| 和林格尔县| 雷波县| 灌阳县| 泽库县| 锡林郭勒盟| 繁昌县| 壶关县| 河曲县| 黄大仙区| 彝良县| 泸定县| 闽侯县| 胶州市| 高平市| 基隆市| 泰和县| 铁力市| 平南县|