vue3自定義指令看完這篇就入門了
前言
這篇文章介紹vue組件中的自定義指令!看完不會(huì)你打我。哈哈哈,開玩笑的??!
1. 什么是自定義指令
vue 官方提供了 v-for、v-model、v-if 等常用的內(nèi)置指令。除此之外 vue 還允許開發(fā)者自定義指令。
vue 中的自定義指令分為兩類,分別是:
- 私有自定義指令
- 全局自定義指令
2. 聲明私有自定義指令的語法
在每個(gè) vue 組件中,可以在 directives 節(jié)點(diǎn)下聲明私有自定義指令。示例代碼如下:
<script>
export default {
directives: {
// 自定義私有指令focus,在使用的時(shí)候要用 v-focus 。
focus: {
mounted(el) {
el.focus()
},
},
},
}
</script>
3. 使用自定義指令
在使用自定義指令時(shí),需要加上 v- 前綴。示例代碼如下:
<!-- 聲明自定義私有指令focus,在使用的時(shí)候要用 v-focus 。 --> <input v-focus/>
4. 聲明全局自定義指令的語法
全局共享的自定義指令需要通過“單頁(yè)面應(yīng)用程序的實(shí)例對(duì)象”進(jìn)行聲明,示例代碼如下:
import { createApp } from 'vue'
const app = createApp({
/* ... */
})
// 注冊(cè)(對(duì)象形式的指令)
app.directive('my-directive', {
/* 自定義指令鉤子 */
})
// 注冊(cè)(函數(shù)形式的指令)
app.directive('my-directive', () => {
/* ... */
})
// 得到一個(gè)已注冊(cè)的指令
const myDirective = app.directive('my-directive')
5. updated 函數(shù)
mounted 函數(shù)只在元素第一次插入 DOM 時(shí)被調(diào)用,當(dāng) DOM 更新時(shí) mounted 函數(shù)不會(huì)被觸發(fā)。 updated 函數(shù)會(huì)在每次 DOM 更新完成后被調(diào)用。示例代碼如下:
// 聲明全局自定義指令
app.directive('focus', {
mounted(el) {
console.log('mounted')
el.focus()
},
updated(el) {
console.log('updated')
el.focus()
},
})
注意:在 vue2 的項(xiàng)目中使用自定義指令時(shí),【 mounted 要換成 bind 】【 updated 要換成 update 】
6. 函數(shù)簡(jiǎn)寫
如果 mounted 和updated 函數(shù)中的邏輯完全相同,則可以簡(jiǎn)寫成如下格式:
app.directive('focus', (el) => {
// 在 mounted 和 updated 都會(huì)觸發(fā)這個(gè)函數(shù)方法
el.focus()
})
7. 指令的參數(shù)值
在綁定指令時(shí),可以通過“等號(hào)”的形式為指令綁定具體的參數(shù)值,示例代碼如下:
// 自定義 v-color 指令
app.directive('color', (el, binding) => {
// binding.value 就是通過 = 綁定的值,在傳值的時(shí)候傳到這 binding.value
el.style.color = binding.value
})
附:下面根據(jù)自定義指令知識(shí)點(diǎn)衍生的一個(gè)小例子
該例子沒有特別的技術(shù)難點(diǎn)。只是為了驗(yàn)證一下這兩天學(xué)習(xí)的vue3部分知識(shí)點(diǎn),存粹是一個(gè)練手記錄~~~
//示例
<template>
<p>
改變方向:<input type="text" v-model="direction" />
</p>
<p>
改變數(shù)值:<input type="range" min="0" :max="maxNum" v-model="pinPadding" />
</p>
<p>
<button @click="reset">重置</button>
</p>
<div style="position: relative;border: 1px solid red;width: 800px;height: 400px;margin: 0 auto;">
<p v-pin:[direction]="pinPadding">數(shù)據(jù):{{pinPadding}},方向:{{direction}}</p>
</div>
</template>
<script>
import two from './components/two.vue'
import {
ref,
reactive,
defineComponent,
computed
} from 'vue'
export default ({
name: 'lycApp',
components: {
two
},
setup(prop, context) {
const direction = ref('left')
const pinPadding = ref(0)
const reset = () => {
direction.value = 'left'
pinPadding.value = 0
}
const maxNum = computed(()=>{
if(direction.value == 'right' || direction.value == 'left'){
return 650
}else{
return 360
}
})
return {
direction,
pinPadding,
reset,
maxNum
}
},
directives: {
pin: {
mounted(el, binding) {
el.style.position = 'absolute'
const s = binding.arg
el.style[s] = binding.value + 'px'
},
updated(el, binding) {
el.removeAttribute('style')
el.style.position = 'absolute'
const s = binding.arg
el.style[s] = binding.value + 'px'
}
}
}
})
</script>
//效果圖

可以在紅色線框內(nèi)隨便改變方向跟距離。
總結(jié)
到此這篇關(guān)于vue3自定義指令的文章就介紹到這了,更多相關(guān)vue3自定義指令內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
vue鼠標(biāo)hover(懸停)改變background-color移入變色問題
這篇文章主要介紹了vue鼠標(biāo)hover(懸停)改變background-color移入變色問題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2022-10-10
element自定義表單驗(yàn)證上傳身份證正反面的實(shí)現(xiàn)
表單驗(yàn)證在很多地方都可以用的到,本文主要介紹了element自定義表單驗(yàn)證上傳身份證正反面的實(shí)現(xiàn),文中根據(jù)實(shí)例編碼詳細(xì)介紹的十分詳盡,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2022-03-03
Vue項(xiàng)目中定義全局變量的幾種常用方法總結(jié)
在項(xiàng)目中經(jīng)常有些函數(shù)和變量是需要復(fù)用,比如說網(wǎng)站服務(wù)器地址,從后臺(tái)拿到的用戶的登錄token,用戶的地址信息等,這時(shí)候就需要設(shè)置一波全局變量,這篇文章主要給大家介紹了關(guān)于Vue項(xiàng)目中定義全局變量的幾種常用方法的相關(guān)資料,需要的朋友可以參考下2023-12-12
一步步教你搭建VUE+VScode+elementUI開發(fā)環(huán)境
這篇文章主要給大家介紹了關(guān)于搭建VUE+VScode+elementUI開發(fā)環(huán)境的相關(guān)資料,近期被配置環(huán)境的事情弄得整個(gè)人都要炸了,現(xiàn)在整理如下,希望有相同需求的朋友可以不用走彎路,需要的朋友可以參考下2023-07-07
vue導(dǎo)出excel和echart圖形分別在不同工作表的實(shí)現(xiàn)方法
這篇文章主要給大家介紹了如何使用vue實(shí)現(xiàn)導(dǎo)出excel和echart圖形分別在不同工作表,文中有詳細(xì)的代碼示例供大家參考,對(duì)大家的學(xué)習(xí)或工作有一定的幫助,需要的朋友可以參考下2023-10-10
vue + webpack如何繞過QQ音樂接口對(duì)host的驗(yàn)證詳解
這篇文章主要給大家介紹了關(guān)于利用vue + webpack如何繞過QQ音樂接口對(duì)host的驗(yàn)證的相關(guān)資料,文中通過示例代碼介紹的非常詳細(xì),需要的朋友可以參考借鑒,下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2018-07-07
Vue3?echarts組件化及使用hook進(jìn)行resize方式
這篇文章主要介紹了Vue3?echarts組件化及使用hook進(jìn)行resize方式,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2023-04-04

