vue?禁止重復(fù)點(diǎn)擊發(fā)送多次請求的實(shí)現(xiàn)
某些情況下,為了阻止用戶短時間內(nèi)重復(fù)點(diǎn)擊某個按鈕,導(dǎo)致前端向后端重復(fù)發(fā)送多次請求。
1.通過控制 loading 來設(shè)置 loading,或者 disabled
剛開始直接給按鈕加上loading效果,即在請求前 loading為true, 在請求結(jié)束finally里loading置為false,以達(dá)到阻止重復(fù)點(diǎn)擊的問題,但部分請求短時間內(nèi),用戶依然可以雙擊觸發(fā)多次請求。
2.使用Vue自定義指令
// 全局注冊自定義指令 Vue.directive("resetClick", { inserted(el, binding) { el.addEventListener("click", () => { if (!el.disabled) { el.disabled = true; el.style.cursor = "not-allowed"; setTimeout(() => { el.disabled = false; el.style.cursor = "pointer"; }, binding.value || 1000); } }); }, }); // 組件內(nèi)使用 <el-button type="primary" v-resetClick="1000" @click="confirm"> 確 定 </el-button>
3. 使用debounce函數(shù)
在工具類util.js文件中定義 防抖函數(shù) (或直接使用第三方庫 throttle-debounce等)
// 防抖debounce代碼: function debounce(fn, delay) { let timeout = null // 創(chuàng)建一個標(biāo)記用來存放定時器的返回值 return function (e) { // 每當(dāng)用戶輸入的時候把前一個 setTimeout clear 掉 clearTimeout(timeout) // 然后又創(chuàng)建一個新的 setTimeout, 這樣就能保證interval 間隔內(nèi)如果時間持續(xù)觸發(fā),就不會執(zhí)行 fn 函數(shù) timeout = setTimeout(() => { fn.apply(this, arguments) timeout = null }, delay) } }
vue組件中使用
<template> <div> <el-button type="primary" @click="handleClick">快速連續(xù)點(diǎn)擊</el-button> </div> </template> <script> import { debounce } from '@/util/util.js' export default { data() { return {} }, methods: { handleClick: debounce(() => { console.log('刪除操作等業(yè)務(wù)邏輯') }, 500), }, } </script> <style></style>
以上兩種方式都存在問題
這兩種方式已經(jīng)基本上能滿足防重復(fù)點(diǎn)擊的需求,但實(shí)際測試時發(fā)現(xiàn)延時的時間不好控,如果延時時間短(<150ms)快速點(diǎn)擊還是會有幾率多次觸發(fā)事件。如果延時時間長(>600ms),用戶點(diǎn)擊后會有個明顯的延時過程才能觸發(fā)事件,用戶體驗(yàn)就不太好。
首先明確下我們想要實(shí)現(xiàn)的效果。
- 用戶在按下按鈕的時候立即觸發(fā)點(diǎn)擊事件。
- 用戶在快速連續(xù)按下按鈕的時候只觸發(fā)第一次的點(diǎn)擊事件。
- 用戶不間斷瘋狂點(diǎn)擊按鈕(暴力測試),也只是立即觸發(fā)第一次的事件,在瘋狂點(diǎn)擊的過程中不會觸發(fā)事件,即使超時時間已經(jīng)過去。
4.最終解決方案lodash
npm i lodash -S
組件中使用
<template> <div> <el-button type="primary" @click="handleClick">快速連續(xù)點(diǎn)擊</el-button> </div> </template> <script> import { debounce } from 'lodash' export default { data() { return {} }, methods: { handleClick: debounce( () => { console.log('刪除操作等業(yè)務(wù)邏輯') }, 500, { leading: true, // 在延遲開始前立即調(diào)用事件 trailing: false, // 在延時結(jié)束后不調(diào)用,保證事件只被觸發(fā)一次 }, ), }, } </script>
到此這篇關(guān)于vue 禁止重復(fù)點(diǎn)擊發(fā)送多次請求的實(shí)現(xiàn)的文章就介紹到這了,更多相關(guān)vue 禁止重復(fù)點(diǎn)擊內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
手寫Vue源碼之?dāng)?shù)據(jù)劫持示例詳解
這篇文章主要給大家介紹了手寫Vue源碼之?dāng)?shù)據(jù)劫持的相關(guān)資料,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2021-01-01vue自定義指令實(shí)現(xiàn)元素滑動移動端適配及邊界處理
這篇文章主要為大家介紹了vue自定義指令實(shí)現(xiàn)元素滑動移動端適配及邊界處理詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2022-09-09Vue如何實(shí)現(xiàn)數(shù)據(jù)的上移和下移
這篇文章主要介紹了Vue如何實(shí)現(xiàn)數(shù)據(jù)的上移和下移問題,具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教2024-06-06vue 組件數(shù)據(jù)加載解析順序的詳細(xì)代碼
Vue.js的解析順序可以概括為:模板編譯、組件創(chuàng)建、數(shù)據(jù)渲染、事件處理和生命周期鉤子函數(shù)執(zhí)行,接下來通過本文給大家介紹vue 組件數(shù)據(jù)加載解析順序的完整代碼,感興趣的朋友跟隨小編一起看看吧2024-03-03利用Vue實(shí)現(xiàn)將圖片轉(zhuǎn)換為Base64編碼的方法
這篇文章主要介紹了利用Vue實(shí)現(xiàn)將圖片轉(zhuǎn)換為Base64編碼的方法,Base64是一種編碼方式,用于將二進(jìn)制數(shù)據(jù)轉(zhuǎn)換成64個基于ASCII的可打印字符,這種編碼可嵌入圖像到HTML或CSS中,減少加載時間,解決跨域問題,并支持離線應(yīng)用開發(fā),需要的朋友可以參考下2024-10-10關(guān)于vue.js中實(shí)現(xiàn)方法內(nèi)某些代碼延時執(zhí)行
今天小編就為大家分享一篇關(guān)于vue.js中實(shí)現(xiàn)方法內(nèi)某些代碼延時執(zhí)行,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧2019-11-11