91超碰碰碰碰久久久久久综合_超碰av人澡人澡人澡人澡人掠_国产黄大片在线观看画质优化_txt小说免费全本

溫馨提示×

溫馨提示×

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

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

怎么在Vue中利用指令禁止反復發送請求

發布時間:2021-05-20 18:00:08 來源:億速云 閱讀:232 作者:Leah 欄目:web開發

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

    1、在按鈕點擊發起請求后,彈個蒙層,顯示個loading,等請求數據返回了將蒙層隱藏掉。

    2、在按鈕點擊發起請求后,將按鈕禁用掉,同樣等數據返回了將按鈕禁用解除。

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

  實現上最簡單的肯定是在需要的頁面種在請求前和拿到數據后,單獨處理。這種方案優點僅僅是簡單,但是每個需要處理的頁面都要單獨寫一串重復的代碼,哪怕利用mixin也要多不少冗余代碼。

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

  以第二種方式為例:

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);
 },
};

    指令的邏輯很簡單,當按鈕插入到DOM節點后,添加一個監聽click的事件,當按鈕點擊后,就將按鈕禁用,并加上一個禁用樣式,并在3s后將該按鈕解除禁用。

  再考慮請求,以axios為例:

api.js

import axios from 'axios';
export baseURL = 'xxxx';
const api = axios.create({
 baseURL,<br data-filtered="filtered"> timeout: 3000,
});
/* 記錄當前請求是否完成 */
window.currentResq = {
 done: true,
 config: {},
};
api.interceptors.request.use(function(config) {
 clearTimeout(resqTimer);
 window.currentResq = {
  done: false,
  config,
 };
 // 接口請求時長超過3s,則視為完成,不管請求結果成功或失敗
 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;

  用一個全局的currentResq來作為請求是否完成的標志。在axios請求攔截器種,將當前請求的數據記錄在currentResq中,并將done設置為false。在axios響應攔截器中,約定url,method,data3個參數一樣時,就是當前currentResq中記錄的請求返回數據,并將done設置為true。

  同樣的在指令邏輯中加入一個輪詢監聽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是一套用于構建用戶界面的漸進式JavaScript框架,Vue與其它大型框架的區別是,使用Vue可以自底向上逐層應用,其核心庫只關注視圖層,方便與第三方庫和項目整合,且使用Vue可以采用單文件組件和Vue生態系統支持的庫開發復雜的單頁應用。

看完上述內容,你們對怎么在Vue中利用指令禁止反復發送請求有進一步的了解嗎?如果還想了解更多知識或者相關內容,請關注億速云行業資訊頻道,感謝大家的支持。

向AI問一下細節

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

vue
AI

德惠市| 松溪县| 竹山县| 徐闻县| 巴中市| 喀喇沁旗| 惠来县| 渝北区| 塘沽区| 马鞍山市| 利川市| 玉田县| 伊宁县| 施秉县| 平南县| 霍州市| 兴和县| 雅江县| 颍上县| 视频| 日喀则市| 万盛区| 临西县| 新津县| 佛教| 莆田市| 怀安县| 高青县| 宜兰县| 五常市| 鹤壁市| 邹城市| 读书| 张家港市| 潮安县| 柘荣县| 通许县| 怀宁县| 嘉善县| 山阳县| 平乐县|