欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

Vue3 全局使用按鈕截流指令示例代碼

 更新時間:2023年05月08日 14:45:30   作者:前端小芬芬  
這篇文章主要介紹了Vue3 全局使用按鈕截流指令示例代碼,Vue2與Vue3中的自定義指令實現(xiàn)方式略有不同,但實現(xiàn)的按鈕截流功能是類似的,本文通過示例代碼給大家介紹的非常詳細(xì),需要的朋友可以參考下

在Vue3中,全局使用按鈕截流指令的方法與Vue2中有所不同,可以根據(jù)以下步驟進(jìn)行: 

1.創(chuàng)建一個自定義指令文件,例如throttle.js,該文件中實現(xiàn)按鈕截流邏輯的代碼。示例代碼如下:

export default {
  mounted(el, binding) {
    let timeoutId;
    const delay = parseInt(binding.value) || 2000; // 獲取指令參數(shù),如果沒有,則默認(rèn)為 2000ms
    el.addEventListener('click', () => {
      if (!el.disabled) {
        el.disabled = true;
        clearTimeout(timeoutId); // 清除之前的定時器
        timeoutId = setTimeout(() => {
          el.disabled = false;
        }, delay);
      }
    });
  },
};

2.在main.js中全局引入該自定義指令,并將其注冊到應(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方法用于全局注冊自定義指令,將自定義指令注冊到Vue應(yīng)用程序中。通過此方法,可以在整個應(yīng)用程序中使用該指令,而不需要重復(fù)定義或?qū)胫噶睢?/p>

1.在模板中使用該自定義指令。在模板中使用該指令的方法與Vue2中相同,示例如下:

<template>
  <div>
    <button v-throttle.click="2000">Click Me</button>
  </div>
</template>

在上述代碼中,v-throttle.click表示注冊的自定義指令名稱,后面的 .click表示該指令對應(yīng)原生的click事件,.2000表示傳入的參數(shù)為2000ms,也可以省略。

需要注意的是,在Vue3中,app.directive方法用于全局注冊自定義指令,不再支持在組件實例選項中注冊全局指令。因此,如果需要在組件內(nèi)使用自定義指令,需要在組件內(nèi)部使用局部自定義指令,并將其作為選項傳遞給Vue組件實例。

Vue2與Vue3中的自定義指令實現(xiàn)方式略有不同,但實現(xiàn)的按鈕截流功能是類似的。

在Vue2中,可以通過以下代碼實現(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,表示指令綁定到元素上時執(zhí)行的函數(shù)。在上述代碼中,指令綁定到按鈕的點擊事件上,在點擊事件發(fā)生時,將按鈕禁用,并設(shè)定一個延時,在延時結(jié)束后,將按鈕恢復(fù)為啟用狀態(tài)。

到此這篇關(guān)于Vue3 全局使用按鈕截流指令示例代碼的文章就介紹到這了,更多相關(guān)Vue3按鈕截流指令內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • 使用Vant完成DatetimePicker 日期的選擇器操作

    使用Vant完成DatetimePicker 日期的選擇器操作

    這篇文章主要介紹了使用Vant完成DatetimePicker 日期的選擇器操作,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2020-11-11
  • 在Vue項目中,防止頁面被縮放和放大示例

    在Vue項目中,防止頁面被縮放和放大示例

    今天小編就為大家分享一篇在Vue項目中,防止頁面被縮放和放大示例,具有很好的參考 價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2019-10-10
  • vant組件庫之tag漸變色不起作用的原因及解決

    vant組件庫之tag漸變色不起作用的原因及解決

    這篇文章主要介紹了vant組件庫之tag漸變色不起作用的原因及解決方案,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2022-04-04
  • Vue通過字符串關(guān)鍵字符實現(xiàn)動態(tài)渲染input輸入框

    Vue通過字符串關(guān)鍵字符實現(xiàn)動態(tài)渲染input輸入框

    這篇文章主要為大家詳細(xì)介紹了Vue如何通過字符串關(guān)鍵字符實現(xiàn)動態(tài)渲染input輸入框。文中的示例代碼講解詳細(xì),感興趣的小伙伴可以了解一下
    2022-12-12
  • Vue表單驗證插件的制作過程

    Vue表單驗證插件的制作過程

    這篇文章主要為大家詳細(xì)介紹了Vue表單驗證插件的制作過程,文中示例代碼介紹的非常詳細(xì),具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2017-04-04
  • Vue.js 2.0 移動端拍照壓縮圖片上傳預(yù)覽功能

    Vue.js 2.0 移動端拍照壓縮圖片上傳預(yù)覽功能

    這篇文章主要介紹了Vue.js 2.0 移動端拍照壓縮圖片上傳預(yù)覽功能,非常不錯,具有參考借鑒價值,需要的朋友可以參考下
    2017-03-03
  • vue路由攔截的三種方法小結(jié)

    vue路由攔截的三種方法小結(jié)

    本文給大家介紹了vue路由攔截的三種方法,全局前置守衛(wèi),路由獨享守衛(wèi)和全局后置鉤子這三種方法,并通過代碼示例給大家介紹的非常詳細(xì),對大家的學(xué)習(xí)或工作有一定的幫助,需要的朋友可以參考下
    2024-02-02
  • vue實現(xiàn)登錄時滑塊驗證

    vue實現(xiàn)登錄時滑塊驗證

    這篇文章主要為大家詳細(xì)介紹了vue實現(xiàn)登錄時滑塊驗證,文中示例代碼介紹的非常詳細(xì),具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2022-03-03
  • 詳解vue項目首頁加載速度優(yōu)化

    詳解vue項目首頁加載速度優(yōu)化

    這篇文章主要介紹了詳解vue項目首頁加載速度優(yōu)化,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2017-10-10
  • vue實現(xiàn)列表無縫滾動

    vue實現(xiàn)列表無縫滾動

    這篇文章主要為大家詳細(xì)介紹了vue實現(xiàn)列表無縫滾動,文中示例代碼介紹的非常詳細(xì),具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2021-06-06

最新評論