怎么在Vue中利用指令禁止反復(fù)發(fā)送請(qǐng)求

今天就跟大家聊聊有關(guān)怎么在Vue中利用指令禁止反復(fù)發(fā)送請(qǐng)求,可能很多人都不太了解,為了讓大家更加了解,小編給大家總結(jié)了以下內(nèi)容,希望大家根據(jù)這篇文章可以有所收獲。

為玉龍等地區(qū)用戶提供了全套網(wǎng)頁(yè)設(shè)計(jì)制作服務(wù),及玉龍網(wǎng)站建設(shè)行業(yè)解決方案。主營(yíng)業(yè)務(wù)為成都網(wǎng)站設(shè)計(jì)、網(wǎng)站制作、玉龍網(wǎng)站設(shè)計(jì),以傳統(tǒng)方式定制建設(shè)網(wǎng)站,并提供域名空間備案等一條龍服務(wù),秉承以專業(yè)、用心的態(tài)度為用戶提供真誠(chéng)的服務(wù)。我們深信只要達(dá)到每一位用戶的要求,就會(huì)得到認(rèn)可,從而選擇與我們長(zhǎng)期合作。這樣,我們也可以走得更遠(yuǎn)!

1、在按鈕點(diǎn)擊發(fā)起請(qǐng)求后,彈個(gè)蒙層,顯示個(gè)loading,等請(qǐng)求數(shù)據(jù)返回了將蒙層隱藏掉。

2、在按鈕點(diǎn)擊發(fā)起請(qǐng)求后,將按鈕禁用掉,同樣等數(shù)據(jù)返回了將按鈕禁用解除。

以上是比較常見的2種方案。

實(shí)現(xiàn)上最簡(jiǎn)單的肯定是在需要的頁(yè)面種在請(qǐng)求前和拿到數(shù)據(jù)后,單獨(dú)處理。這種方案優(yōu)點(diǎn)僅僅是簡(jiǎn)單,但是每個(gè)需要處理的頁(yè)面都要單獨(dú)寫一串重復(fù)的代碼,哪怕利用mixin也要多不少冗余代碼。

如果是利用指令的方式僅僅需要在合適的地方加上個(gè)一條v-xxxx,其他都在指令的邏輯內(nèi)統(tǒng)一處理。

以第二種方式為例:

clickForbidden.js

let forbidClick = null;
export default {
 bind(e) {
  const el = e;
  let timer = null;
  forbidClick = () => {
   el.disabled = true;
   el.classList.add('is-disabled');
   timer = setTimeout(() => {
     el.disabled = false; 
    el.classList.remove('is-disabled');
   }, 3000);
  };
  el.addEventListener('click', forbidClick);
 },
 unbind() {
  document.removeEventListener('click', forbidClick);
 },
};

指令的邏輯很簡(jiǎn)單,當(dāng)按鈕插入到DOM節(jié)點(diǎn)后,添加一個(gè)監(jiān)聽click的事件,當(dāng)按鈕點(diǎn)擊后,就將按鈕禁用,并加上一個(gè)禁用樣式,并在3s后將該按鈕解除禁用。

再考慮請(qǐng)求,以axios為例:

api.js

import axios from 'axios';
export baseURL = 'xxxx';
const api = axios.create({
 baseURL,<br data-filtered="filtered"> timeout: 3000,
});
/* 記錄當(dāng)前請(qǐng)求是否完成 */
window.currentResq = {
 done: true,
 config: {},
};
api.interceptors.request.use(function(config) {
 clearTimeout(resqTimer);
 window.currentResq = {
  done: false,
  config,
 };
 // 接口請(qǐng)求時(shí)長(zhǎng)超過(guò)3s,則視為完成,不管請(qǐng)求結(jié)果成功或失敗
 resqTimer = setTimeout(() => {
  window.currentResq = {
   done: true,
   config: {},
  };
 }, 3000);
});
api.interceptors.response.use(function(response) {
 const { config } = window.currentResq;
 const { url, method, data } = response.config;
 if (config.url === url && config.method === method && config.data === data) {
  clearTimeout(resqTimer);
  window.currentResq.done = true;
 }
 return response;
}, function (error) {
 return error;
});
 
export default api;

用一個(gè)全局的currentResq來(lái)作為請(qǐng)求是否完成的標(biāo)志。在axios請(qǐng)求攔截器種,將當(dāng)前請(qǐng)求的數(shù)據(jù)記錄在currentResq中,并將done設(shè)置為false。在axios響應(yīng)攔截器中,約定url,method,data3個(gè)參數(shù)一樣時(shí),就是當(dāng)前currentResq中記錄的請(qǐng)求返回?cái)?shù)據(jù),并將done設(shè)置為true。

同樣的在指令邏輯中加入一個(gè)輪詢監(jiān)聽currentResq的done是否完成。

clickForbidden.js 

let forbidClick = null;
export default {
 bind(e) {
  const el = e;
  let timer = null;
  forbidClick = () => {
   el.disabled = true;
   el.classList.add('is-disabled');
   timer = setInterval(() => {
    if (window.currentResq.done) {
     clearInterval(timer);
     el.disabled = false;
     el.classList.remove('is-disabled');
    }
   }, 500);
  };
  el.addEventListener('click', forbidClick);
 },
 unbind() {
  document.removeEventListener('click', forbidClick);
 },
};

vue是什么

Vue是一套用于構(gòu)建用戶界面的漸進(jìn)式JavaScript框架,Vue與其它大型框架的區(qū)別是,使用Vue可以自底向上逐層應(yīng)用,其核心庫(kù)只關(guān)注視圖層,方便與第三方庫(kù)和項(xiàng)目整合,且使用Vue可以采用單文件組件和Vue生態(tài)系統(tǒng)支持的庫(kù)開發(fā)復(fù)雜的單頁(yè)應(yīng)用。

看完上述內(nèi)容,你們對(duì)怎么在Vue中利用指令禁止反復(fù)發(fā)送請(qǐng)求有進(jìn)一步的了解嗎?如果還想了解更多知識(shí)或者相關(guān)內(nèi)容,請(qǐng)關(guān)注創(chuàng)新互聯(lián)行業(yè)資訊頻道,感謝大家的支持。

新聞標(biāo)題:怎么在Vue中利用指令禁止反復(fù)發(fā)送請(qǐng)求
文章鏈接:http://muchs.cn/article34/gdisse.html

成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供網(wǎng)站制作、營(yíng)銷型網(wǎng)站建設(shè)、網(wǎng)頁(yè)設(shè)計(jì)公司用戶體驗(yàn)、響應(yīng)式網(wǎng)站、微信公眾號(hào)

廣告

聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請(qǐng)盡快告知,我們將會(huì)在第一時(shí)間刪除。文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如需處理請(qǐng)聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時(shí)需注明來(lái)源: 創(chuàng)新互聯(lián)

成都網(wǎng)站建設(shè)