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

Vue3自定義指令完全指南(附詳細(xì)代碼)

 更新時間:2025年04月27日 09:00:23   作者:john_Asura  
這篇文章主要介紹了Vue3自定義指令的相關(guān)資料,Vue3自定義指令優(yōu)化了生命周期鉤子,提供了更靈活的DOM操作方式,文中通過代碼介紹的非常詳細(xì),需要的朋友可以參考下

基本概念

在Vue3中,自定義指令是用于直接操作DOM的重要工具。相比Vue2,Vue3的指令系統(tǒng)進(jìn)行了優(yōu)化和簡化。

生命周期鉤子

鉤子名稱對應(yīng)Vue2名稱觸發(fā)時機(jī)
createdbind元素屬性綁定前
beforeMountinserted元素插入父節(jié)點前
mounted-元素插入父節(jié)點后
beforeUpdateupdate組件更新前
updatedcomponentUpdated組件及子組件更新后
beforeUnmountunbind元素卸載前
unmounted-元素卸載后

指令注冊方式

全局注冊

// main.js
const app = createApp(App)

app.directive('focus', {
  mounted(el) {
    el.focus()
  }
})

局部注冊

export default {
  directives: {
    highlight: {
      mounted(el, binding) {
        el.style.backgroundColor = binding.value || 'yellow'
      }
    }
  }
}

常用應(yīng)用場景

1. 自動聚焦

// 使用
<input v-focus>

// 實現(xiàn)
app.directive('focus', {
  mounted(el) {
    el.focus()
  }
})

2. 權(quán)限控制

// 使用
<button v-permission="['admin']">刪除</button>

// 實現(xiàn)
app.directive('permission', {
  mounted(el, binding) {
    const roles = ['user', 'editor', 'admin']
    if (!binding.value.includes(roles.current)) {
      el.parentNode.removeChild(el)
    }
  }
})

3. 防抖指令

// 使用
<button v-debounce:click="submitForm">提交</button>

// 實現(xiàn)
app.directive('debounce', {
  mounted(el, binding) {
    let timer = null
    el.addEventListener(binding.arg, () => {
      clearTimeout(timer)
      timer = setTimeout(() => {
        binding.value()
      }, 500)
    })
  }
})

進(jìn)階技巧

動態(tài)參數(shù)傳遞

// 使用
<div v-pin:[direction]="200"></div>

// 實現(xiàn)
app.directive('pin', {
  mounted(el, binding) {
    el.style.position = 'fixed'
    const direction = binding.arg || 'top'
    el.style[direction] = binding.value + 'px'
  }
})

Composition API 結(jié)合

import { useScroll } from './scrollComposable'

app.directive('scroll', {
  mounted(el, binding) {
    const { start, stop } = useScroll(binding.value)
    el._scrollHandler = { start, stop }
    start()
  },
  unmounted(el) {
    el._scrollHandler.stop()
  }
})

注意事項

  • 避免過度使用:優(yōu)先使用組件化方案
  • 參數(shù)驗證:使用binding.value前進(jìn)行類型檢查
  • 性能優(yōu)化:及時在unmounted階段清理副作用
  • 命名規(guī)范:使用小寫字母+連字符格式(如v-custom-directive
  • 瀏覽器兼容:謹(jǐn)慎使用新API,必要時添加polyfill

總結(jié)

場景推薦指令類型示例
DOM操作自定義指令v-tooltip
全局功能全局指令v-permission
復(fù)雜交互組合式指令v-draggable
簡單樣式修改類綁定:class=“…”

通過合理使用自定義指令,可以使代碼更簡潔、維護(hù)性更好,但要注意保持指令的單一職責(zé)原則。

到此這篇關(guān)于Vue3自定義指令的文章就介紹到這了,更多相關(guān)Vue3自定義指令內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • vue或react項目生產(chǎn)環(huán)境去掉console.log的操作

    vue或react項目生產(chǎn)環(huán)境去掉console.log的操作

    這篇文章主要介紹了vue或react項目生產(chǎn)環(huán)境去掉console.log的操作,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2020-09-09
  • Vue3插槽(slot)使用方法詳解

    Vue3插槽(slot)使用方法詳解

    在VUE開發(fā)項目的過程中,插槽<slot>是重要的承載分發(fā)內(nèi)容的出口,下面這篇文章主要給大家介紹了關(guān)于Vue3插槽(slot)使用的相關(guān)資料,文中通過實例代碼介紹的非常詳細(xì),需要的朋友可以參考下
    2022-11-11
  • vue跳轉(zhuǎn)頁面攜帶參數(shù)并且立即執(zhí)行方法

    vue跳轉(zhuǎn)頁面攜帶參數(shù)并且立即執(zhí)行方法

    這篇文章主要介紹了vue跳轉(zhuǎn)頁面攜帶參數(shù)并且立即執(zhí)行方法,首先定義跳轉(zhuǎn)函數(shù),結(jié)合實例代碼給大家介紹的非常詳細(xì),需要的朋友參考下吧
    2023-10-10
  • vue 動態(tài)組件component

    vue 動態(tài)組件component

    這篇文章主要介紹了 vue 動態(tài)組件component ,vue提供了一個內(nèi)置的<component>,專門用來實現(xiàn)動態(tài)組件的渲染,這個標(biāo)簽就相當(dāng)于一個占位符,需要使用is屬性指定綁定的組件,想了解更多詳細(xì)內(nèi)容的小伙伴請參考下面文章的具體內(nèi)容
    2021-11-11
  • 關(guān)于vue自適應(yīng)布局(各種瀏覽器,分辨率)的示例代碼

    關(guān)于vue自適應(yīng)布局(各種瀏覽器,分辨率)的示例代碼

    這篇文章主要介紹了vue自適應(yīng)布局(各種瀏覽器,分辨率),主要使用了flex布局的flex:1屬性和自適應(yīng)的css+vh+百分比這種方式,開局設(shè)置overflow:hidden,主體main部分要設(shè)置:overflow:auto,需要的朋友可以參考下
    2022-09-09
  • vue實力踩坑?當(dāng)前頁push當(dāng)前頁無效的解決

    vue實力踩坑?當(dāng)前頁push當(dāng)前頁無效的解決

    這篇文章主要介紹了vue實力踩坑?當(dāng)前頁push當(dāng)前頁無效的解決方案,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2022-04-04
  • Echarts+VUE柱狀圖繪制細(xì)節(jié)并且屏幕自適應(yīng)完整代碼

    Echarts+VUE柱狀圖繪制細(xì)節(jié)并且屏幕自適應(yīng)完整代碼

    柱狀圖(或稱條形圖)是一種通過柱形的長度來表現(xiàn)數(shù)據(jù)大小的一種常用圖表類型,這篇文章主要給大家介紹了關(guān)于Echarts+VUE柱狀圖繪制細(xì)節(jié)并且屏幕自適應(yīng)的相關(guān)資料,需要的朋友可以參考下
    2024-02-02
  • vue-router中query和params的區(qū)別解析

    vue-router中query和params的區(qū)別解析

    vue-router是Vue.js官方的路由插件,它和vue.js是深度集成的,適合用于構(gòu)建單頁面應(yīng)用,這篇文章主要介紹了vue-router中query和params的區(qū)別 ,需要的朋友可以參考下
    2022-10-10
  • 淺談vue3中ref、toRef、toRefs?和?reactive的區(qū)別

    淺談vue3中ref、toRef、toRefs?和?reactive的區(qū)別

    本文主要介紹了淺談vue3中ref、toRef、toRefs?和?reactive的區(qū)別,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2022-07-07
  • 使用Axios攔截器中止Vue請求的步驟詳解

    使用Axios攔截器中止Vue請求的步驟詳解

    假設(shè)?App?的用戶可以在短時間內(nèi)進(jìn)行多個?API?調(diào)用,但您只想顯示上次調(diào)用的結(jié)果,之前正在進(jìn)行的請求變得無關(guān)緊要,在這種情況下,您可以利用?Axios?攔截器,本文給大家介紹了如何使用Axios攔截器中止Vue請求,需要的朋友可以參考下
    2023-11-11

最新評論