久久精品国产亚洲高清|精品日韩中文乱码在线|亚洲va中文字幕无码久|伊人久久综合狼伊人久久|亚洲不卡av不卡一区二区|精品久久久久久久蜜臀AV|国产精品19久久久久久不卡|国产男女猛烈视频在线观看麻豆

千鋒教育-做有情懷、有良心、有品質(zhì)的職業(yè)教育機(jī)構(gòu)

手機(jī)站
千鋒教育

千鋒學(xué)習(xí)站 | 隨時(shí)隨地免費(fèi)學(xué)

千鋒教育

掃一掃進(jìn)入千鋒手機(jī)站

領(lǐng)取全套視頻
千鋒教育

關(guān)注千鋒學(xué)習(xí)站小程序
隨時(shí)隨地免費(fèi)學(xué)習(xí)課程

當(dāng)前位置:首頁(yè)  >  技術(shù)干貨  > Vue3 中自定義指令(二)

Vue3 中自定義指令(二)

來(lái)源:千鋒教育
發(fā)布人:qyf
時(shí)間: 2022-08-02 17:25:41 1659432341

  2.2 七個(gè)鉤子函數(shù)

  在 Vue3 中,自定義指令的鉤子函數(shù)主要有如下七種(這塊跟 Vue2 差異較大):

  created:在綁定元素的 attribute 或事件監(jiān)聽器被應(yīng)用之前調(diào)用。在指令需要附加在普通的 v-on 事件監(jiān)聽器調(diào)用前的事件監(jiān)聽器中時(shí),這很有用。

  beforeMount:當(dāng)指令第一次綁定到元素并且在掛載父組件之前調(diào)用。

  mounted:在綁定元素的父組件被掛載后調(diào)用,大部分自定義指令都寫在這里。

  beforeUpdate:在更新包含組件的 VNode 之前調(diào)用。

  updated:在包含組件的 VNode 及其子組件的 VNode 更新后調(diào)用。

  beforeUnmount:在卸載綁定元素的父組件之前調(diào)用

  unmounted:當(dāng)指令與元素解除綁定且父組件已卸載時(shí),只調(diào)用一次。

  雖然鉤子函數(shù)比較多,看著有點(diǎn)唬人,不過(guò)我們?nèi)粘i_發(fā)中用的最多的其實(shí)是 mounted 函數(shù)。

  2.3 四個(gè)參數(shù)

  這里七個(gè)鉤子函數(shù),鉤子函數(shù)中有回調(diào)參數(shù),回調(diào)參數(shù)有四個(gè),含義基本上和 Vue2 一致:

  el:指令所綁定的元素,可以用來(lái)直接操作 DOM,我們松哥說(shuō)想實(shí)現(xiàn)一個(gè)可以自動(dòng)判斷組件顯示還是隱藏的指令,那么就可以通過(guò) el 對(duì)象來(lái)操作 DOM 節(jié)點(diǎn),進(jìn)而實(shí)現(xiàn)組件的隱藏。

  binding:我們通過(guò)自定義指令傳遞的各種參數(shù),主要存在于這個(gè)對(duì)象中,該對(duì)象屬性較多,如下屬性是我們?nèi)粘i_發(fā)使用較多的幾個(gè):

  name:指令名,不包括 v- 前綴。

  value:指令的綁定值,例如:v-hasPermission="['user:delete']" 中,綁定值為 'user:delete',不過(guò)需要小伙伴們注意的是,這個(gè)綁定值可以是數(shù)組也可以是普通對(duì)象,關(guān)鍵是看你具體綁定的是什么,在 2.1 小節(jié)的案例中,我們的 value 就是一個(gè)數(shù)字。

  expression:字符串形式的指令表達(dá)式。例如 v-my-directive=“1 + 1” 中,表達(dá)式為 “1 + 1”。

  arg:傳給指令的參數(shù),可選。例如 v-hasPermission:[name]="'zhangsan'" 中,參數(shù)為 “name”。

  vnode:Vue 編譯生成的虛擬節(jié)點(diǎn)。

  oldVnode:上一個(gè)虛擬節(jié)點(diǎn),僅在 update 和 componentUpdated 鉤子中可用。

  除了 el 之外,其它參數(shù)都應(yīng)該是只讀的,切勿進(jìn)行修改。如果需要在鉤子之間共享數(shù)據(jù),建議通過(guò)元素的 dataset 來(lái)進(jìn)行。

  2.4 動(dòng)態(tài)參數(shù)

  有一種動(dòng)態(tài)參數(shù),這里也和小伙伴們分享下。正常情況下,我們自定義指令時(shí)傳遞的參數(shù)都是通過(guò) binding.value 來(lái)獲取到的,不過(guò)在這之外還有一種方式就是通過(guò) binding.arg 獲取參數(shù)。

  我舉一個(gè)簡(jiǎn)單例子,假設(shè)我們上面這個(gè) onceClick 指令,默認(rèn)的時(shí)間單位時(shí)毫秒,假設(shè)現(xiàn)在想給時(shí)間設(shè)置單位,那么我們就可以這樣寫:

1

  在自定義指令的時(shí)候,獲取到 binding.arg 的值,這樣就可以知道時(shí)間單位了,在使用該指令的時(shí)候,方式如下:

2

  timeUnit 是一個(gè)提前定義好的變量。

  3. 自定義權(quán)限指令

  好啦,有了上面的基礎(chǔ)知識(shí),接下來(lái)就來(lái)看我們本文的主題,自定義權(quán)限指令,我寫一個(gè)簡(jiǎn)單的例子大家來(lái)看下

3

  usersPermissions 表示當(dāng)前用戶所具備的權(quán)限,正常該數(shù)據(jù)應(yīng)該是從服務(wù)端加載而來(lái),但是我這里簡(jiǎn)單起見,就直接定義好了。

  具體的邏輯很簡(jiǎn)單,先從 binding 中提取出 value 的值,這就是當(dāng)前控件所需要的權(quán)限,然后遍歷 usersPermissions 用一個(gè) some 函數(shù),去查看 usersPermissions 中是否有滿足條件的值,如果沒有,說(shuō)明當(dāng)前用戶不具備展示該組件所需要的權(quán)限,那么就要隱藏這個(gè)組件,隱藏的方式就是獲取到當(dāng)前組件的父組件,然后從父組件中移除當(dāng)前組件即可。

  這是一個(gè)全局的指令,定義好之后,我們就可以在組件中直接使用了:

4

  好啦,Vue3 自定義組件學(xué)會(huì)了沒?更多關(guān)于“java培訓(xùn)”的問題,歡迎咨詢千鋒教育在線名師。千鋒教育多年辦學(xué),課程大綱緊跟企業(yè)需求,更科學(xué)更嚴(yán)謹(jǐn),每年培養(yǎng)泛IT人才近2萬(wàn)人。不論你是零基礎(chǔ)還是想提升,都可以找到適合的班型,千鋒教育隨時(shí)歡迎你來(lái)試聽。

tags:
聲明:本站稿件版權(quán)均屬千鋒教育所有,未經(jīng)許可不得擅自轉(zhuǎn)載。
10年以上業(yè)內(nèi)強(qiáng)師集結(jié),手把手帶你蛻變精英
請(qǐng)您保持通訊暢通,專屬學(xué)習(xí)老師24小時(shí)內(nèi)將與您1V1溝通
免費(fèi)領(lǐng)取
今日已有369人領(lǐng)取成功
劉同學(xué) 138****2860 剛剛成功領(lǐng)取
王同學(xué) 131****2015 剛剛成功領(lǐng)取
張同學(xué) 133****4652 剛剛成功領(lǐng)取
李同學(xué) 135****8607 剛剛成功領(lǐng)取
楊同學(xué) 132****5667 剛剛成功領(lǐng)取
岳同學(xué) 134****6652 剛剛成功領(lǐng)取
梁同學(xué) 157****2950 剛剛成功領(lǐng)取
劉同學(xué) 189****1015 剛剛成功領(lǐng)取
張同學(xué) 155****4678 剛剛成功領(lǐng)取
鄒同學(xué) 139****2907 剛剛成功領(lǐng)取
董同學(xué) 138****2867 剛剛成功領(lǐng)取
周同學(xué) 136****3602 剛剛成功領(lǐng)取
相關(guān)推薦HOT
服務(wù)器為什么要用Linux?

服務(wù)器為什么要用Linux作為服務(wù)器操作系統(tǒng)的優(yōu)選,Linux在眾多選擇中脫穎而出。Linux作為服務(wù)器操作系統(tǒng)的優(yōu)選,有其獨(dú)特的優(yōu)勢(shì)和特點(diǎn)。包括其...詳情>>

2023-10-14 12:34:11
ORM解決的主要問題是什么?

ORM(對(duì)象關(guān)系映射)解決的主要問題是將關(guān)系數(shù)據(jù)庫(kù)與面向?qū)ο缶幊讨g的映射困境。在傳統(tǒng)的關(guān)系數(shù)據(jù)庫(kù)中,數(shù)據(jù)以表格的形式存儲(chǔ),而在面向?qū)ο?..詳情>>

2023-10-14 12:26:19
Go為什么不支持三元運(yùn)算符?

Go為什么不支持三元運(yùn)算符Go語(yǔ)言是一種以簡(jiǎn)潔和有效性為目標(biāo)的編程語(yǔ)言,因此在設(shè)計(jì)過(guò)程中,Go的設(shè)計(jì)者刻意排除了一些他們認(rèn)為可能導(dǎo)致復(fù)雜性或...詳情>>

2023-10-14 12:12:36
IT通常說(shuō)的平臺(tái)是什么意思?

在信息技術(shù)(IT)領(lǐng)域,”平臺(tái)”這個(gè)詞有著廣泛的含義,它常常指代支持軟件應(yīng)用開發(fā)和運(yùn)行的基礎(chǔ)框架和環(huán)境。以下是對(duì)”平臺(tái)”這個(gè)概念的更深入...詳情>>

2023-10-14 11:55:36
什么是PowerPivot?

什么是PowerPivotPowerPivot,全稱”PowerPivot for Excel”,是Microsoft提供的一種數(shù)據(jù)分析工具,可以作為Excel的插件使用。通過(guò)PowerPivot,...詳情>>

2023-10-14 11:25:48