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

溫馨提示×

溫馨提示×

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

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

vue如何解決一個方法同時發送多個請求的問題

發布時間:2021-07-20 10:08:46 來源:億速云 閱讀:831 作者:小新 欄目:web開發

這篇文章主要介紹了vue如何解決一個方法同時發送多個請求的問題,具有一定借鑒價值,感興趣的朋友可以參考下,希望大家閱讀完這篇文章之后大有收獲,下面讓小編帶著大家一起了解一下。

在項目開發過程中,讓人抓狂之一的問題就是一個點擊事件,當快速點擊的時候,它會重復發送多個請求。這是不允許出現的。

但是怎么解決這個問題呢?

一般處理方法,就是點擊的時候,立刻將該按鈕disabled,這樣就可以避免重復發送請求了。但是我發現這個有一個弊端,那就是:

如果,該事件有許多的驗證,比如電話、郵箱格式是否正確呀,必填的是否填了呀等等。一旦你點擊就把按鈕disabled了,發現該填的沒填,回去填完后發現按鈕不能點了?那是因為剛才點擊的時候被你disabled了,所以還得在驗證的方法中取消按鈕的disable。就造成了你點擊的時候,第一步,將按鈕disable了,然后一步一步向下驗證,如果驗證出錯,得取消disable,當所有驗證通過了,在請求的回調函數中,成功了也要取消disable,失敗了也要取消disable,因為失敗了用戶多半還會繼續點兩次,不取消disable會讓用戶發現怎么點不了了。這就造成了全篇都是按鈕disable的設置與取消。一旦有修改,很難維護的。

在vue中,有一個lodash,我們只需引入就可以使用了。比如以下代碼:

<template>
 <div>
 <div class="bindBtn">
  <button class="bindDataBtn" @click="postAction">提交</button>
 </div>
 </div>
</template>
<script>
import _ from 'lodash'
export default {
 data() {
 return {
 
 }
 },
 mounted() {
 
 },
 methods: {
 sendAjax(){
  /*這里是請求的接口、參數以及回調函數等*/
 },
 postAction(){
  this.doPostAction()
 }
 },
 created(){
 this.doPostAction = _.debounce(this.sendAjax,500);
 }
}
</script>

我們首先將發送請求的ajax方法寫在一個函數里面,在這里就是sendAjax函數,其次,我們引入lodash,然后將sendAjax這個函數用一個方法自定義一下,在這里就是doPostAction,其中_是我們引入的lodash,_.debounce是一個限制操作頻率的函數,里面的是500是毫秒單位。

當執行點擊事件的時候,也就是postAction函數,我們只需要調用doPostAction這個函數就可以了,而那個500的功能就是你在這個時間段里,無論執行了多少次這個點擊事件,它都只會執行一次。

這樣就少了我們通篇disable來disable去

感謝你能夠認真閱讀完這篇文章,希望小編分享的“vue如何解決一個方法同時發送多個請求的問題”這篇文章對大家有幫助,同時也希望大家多多支持億速云,關注億速云行業資訊頻道,更多相關知識等著你來學習!

向AI問一下細節

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

vue
AI

新源县| 江达县| 新竹县| 安仁县| 新乐市| 呼和浩特市| 武义县| 南昌市| 泗阳县| 卓资县| 望都县| 和静县| 洞口县| 满城县| 和平县| 桓仁| 云霄县| 基隆市| 翁牛特旗| 独山县| 襄汾县| 海丰县| 化州市| 保山市| 兰州市| 江永县| 安塞县| 印江| 米泉市| 台南县| 昆明市| 麦盖提县| 区。| 商洛市| 光泽县| 行唐县| 高陵县| 崇仁县| 峨山| 望城县| 张家口市|