国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 語言 > JavaScript > 正文

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

2024-05-06 15:29:30
字體:
來源:轉載
供稿:網友

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

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

一般處理方法,就是點擊的時候,立刻將該按鈕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解決一個方法同時發送多個請求的問題就是小編分享給大家的全部內容了,希望能給大家一個參考,也希望大家多多支持錯新站長站。

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表

圖片精選

主站蜘蛛池模板: 三都| 增城市| 东乡族自治县| 渝中区| 峨边| 东兴市| 吐鲁番市| 老河口市| 旬邑县| 南宫市| 杭州市| 杨浦区| 武安市| 遵义县| 襄汾县| 富源县| 南乐县| 常山县| 申扎县| 乌兰县| 武夷山市| 衡水市| 滨海县| 潼南县| 九龙坡区| 息烽县| 旬邑县| 桃江县| 南雄市| 通州市| 游戏| 禄丰县| 福清市| 长春市| 察隅县| 盖州市| 五寨县| 乡宁县| 嘉峪关市| 卢龙县| 敖汉旗|