Vue3 全局使用按鈕截流指令示例代碼
在Vue3中,全局使用按鈕截流指令的方法與Vue2中有所不同,可以根據(jù)以下步驟進(jìn)行:
1.創(chuàng)建一個(gè)自定義指令文件,例如throttle.js,該文件中實(shí)現(xiàn)按鈕截流邏輯的代碼。示例代碼如下:
export default { mounted(el, binding) { let timeoutId; const delay = parseInt(binding.value) || 2000; // 獲取指令參數(shù),如果沒(méi)有,則默認(rèn)為 2000ms el.addEventListener('click', () => { if (!el.disabled) { el.disabled = true; clearTimeout(timeoutId); // 清除之前的定時(shí)器 timeoutId = setTimeout(() => { el.disabled = false; }, delay); } }); }, };
2.在main.js中全局引入該自定義指令,并將其注冊(cè)到應(yīng)用程序中。示例代碼如下:
import { createApp } from 'vue'; import App from './App.vue'; import throttle from './directives/throttle'; const app = createApp(App); app.directive('throttle', throttle); app.mount('#app');
在上述代碼中,app.directive
方法用于全局注冊(cè)自定義指令,將自定義指令注冊(cè)到Vue應(yīng)用程序中。通過(guò)此方法,可以在整個(gè)應(yīng)用程序中使用該指令,而不需要重復(fù)定義或?qū)胫噶睢?/p>
1.在模板中使用該自定義指令。在模板中使用該指令的方法與Vue2中相同,示例如下:
<template> <div> <button v-throttle.click="2000">Click Me</button> </div> </template>
在上述代碼中,v-throttle.click
表示注冊(cè)的自定義指令名稱,后面的 .click
表示該指令對(duì)應(yīng)原生的click
事件,.2000
表示傳入的參數(shù)為2000ms,也可以省略。
需要注意的是,在Vue3中,app.directive
方法用于全局注冊(cè)自定義指令,不再支持在組件實(shí)例選項(xiàng)中注冊(cè)全局指令。因此,如果需要在組件內(nèi)使用自定義指令,需要在組件內(nèi)部使用局部自定義指令,并將其作為選項(xiàng)傳遞給Vue組件實(shí)例。
Vue2與Vue3中的自定義指令實(shí)現(xiàn)方式略有不同,但實(shí)現(xiàn)的按鈕截流功能是類似的。
在Vue2中,可以通過(guò)以下代碼實(shí)現(xiàn)按鈕截流指令:
// throttle.js export default { bind(el, binding) { let timeoutId; const delay = parseInt(binding.arg) || 2000; el.addEventListener('click', () => { if (!el.disabled) { el.disabled = true; clearTimeout(timeoutId); timeoutId = setTimeout(() => { el.disabled = false; }, delay); } }); }, };
在Vue2中,自定義指令的鉤子函數(shù)bind
等同于Vue3中的mounted
,表示指令綁定到元素上時(shí)執(zhí)行的函數(shù)。在上述代碼中,指令綁定到按鈕的點(diǎn)擊事件上,在點(diǎn)擊事件發(fā)生時(shí),將按鈕禁用,并設(shè)定一個(gè)延時(shí),在延時(shí)結(jié)束后,將按鈕恢復(fù)為啟用狀態(tài)。
到此這篇關(guān)于Vue3 全局使用按鈕截流指令示例代碼的文章就介紹到這了,更多相關(guān)Vue3按鈕截流指令內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
使用Vant完成DatetimePicker 日期的選擇器操作
這篇文章主要介紹了使用Vant完成DatetimePicker 日期的選擇器操作,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧2020-11-11在Vue項(xiàng)目中,防止頁(yè)面被縮放和放大示例
今天小編就為大家分享一篇在Vue項(xiàng)目中,防止頁(yè)面被縮放和放大示例,具有很好的參考 價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧2019-10-10Vue通過(guò)字符串關(guān)鍵字符實(shí)現(xiàn)動(dòng)態(tài)渲染input輸入框
這篇文章主要為大家詳細(xì)介紹了Vue如何通過(guò)字符串關(guān)鍵字符實(shí)現(xiàn)動(dòng)態(tài)渲染input輸入框。文中的示例代碼講解詳細(xì),感興趣的小伙伴可以了解一下2022-12-12Vue.js 2.0 移動(dòng)端拍照壓縮圖片上傳預(yù)覽功能
這篇文章主要介紹了Vue.js 2.0 移動(dòng)端拍照壓縮圖片上傳預(yù)覽功能,非常不錯(cuò),具有參考借鑒價(jià)值,需要的朋友可以參考下2017-03-03vue實(shí)現(xiàn)登錄時(shí)滑塊驗(yàn)證
這篇文章主要為大家詳細(xì)介紹了vue實(shí)現(xiàn)登錄時(shí)滑塊驗(yàn)證,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2022-03-03詳解vue項(xiàng)目首頁(yè)加載速度優(yōu)化
這篇文章主要介紹了詳解vue項(xiàng)目首頁(yè)加載速度優(yōu)化,小編覺(jué)得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧2017-10-10vue實(shí)現(xiàn)列表無(wú)縫滾動(dòng)
這篇文章主要為大家詳細(xì)介紹了vue實(shí)現(xiàn)列表無(wú)縫滾動(dòng),文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2021-06-06