精品欧美一区二区三区在线观看 _久久久久国色av免费观看性色_国产精品久久在线观看_亚洲第一综合网站_91精品又粗又猛又爽_小泽玛利亚一区二区免费_91亚洲精品国偷拍自产在线观看 _久久精品视频在线播放_美女精品久久久_欧美日韩国产成人在线

手把手教你在 Vue3 中自定義指令

開發 項目管理
先要和小伙伴們說一下,Vue2 和 Vue3 在自定義指令上有一些差異,并不完全一致,下面的介紹主要是針對 Vue3 的介紹。

TienChin 項目前端是 Vue3,前端有這樣的一個需求:有一些前端頁面上的按鈕要根據用戶的權限來決定是否展示出來,如果用戶具備相應的權限,那么就展示對應的按鈕;如果用戶不具備對應的權限,那么按鈕就隱藏起來。大致上就這樣一個需求。

看到這個需求,可能有小伙伴首先想到用 v-if 指令,這個指令確實也能做,但是,由于用戶具備的權限一般來說可能是多個,甚至可能還有通配符,所以這個比對并不是一個容易的事情,肯定得寫方法。。。所以,如果能用一個指令來實現這個功能,那么就會顯得專業很多了。

說干就干,我們來看看 Vue3 中如何自定義指令。

1. 成果展示

我們先來看看實現自定義指令最終的使用方式:

<button @click="btnClick" v-hasPermission="['user:delete']">刪除用戶</button>

小伙伴們看到,這個 v-hasPermission? 就是我們的自定義指令,如果當前用戶具備 user:delete 權限,這個按鈕就會展示出來,如果當前用戶不具備這個權限,這個按鈕就不會展示出來。

2. 指令基礎

先要和小伙伴們說一下,Vue2 和 Vue3 在自定義指令上有一些差異,并不完全一致,下面的介紹主要是針對 Vue3 的介紹。

我先來和小伙伴們分享一下我們具體是怎么做的,然后在講解代碼的時候再來和大家說說各個參數的含義。

2.1 兩種作用域

自定義指令可以定義全局的,也可以定義局部的。

在正式開搞之前,小伙伴們需要先明白,自定義指令有兩種作用域,一種是局部的自定義指令,還有一種是全局的自定義指令。局部的自定義指令就只能在當前 .vue? 文件中使用,全局的則可以在所有的 .vue 文件中使用。

2.1.1 局部指令

直接在當前 .vue 文件中定義即可,如下:

directives: {
focus: {
// 指令的定義
mounted(el) {
el.focus()
}
}
}

不過,在 Vue3 中,也可以這樣寫:

<template>
<div>
<button v-onceClick="10000" @click="btnClick">ClickMe</button>
</div>
</template>

<script>

import {ref} from 'vue';

export default {
name: "MyVue01",
setup() {
const a = ref(1);
const btnClick = () => {
a.value++;
}
return {a, btnClick}
},
directives: {
onceClick: {
mounted(el, binding, vnode) {
el.addEventListener('click', () => {
if (!el.disabled) {
el.disabled = true;
setTimeout(() => {
el.disabled = false;
}, binding.value || 1000);
}
});
}
}
}
}
</script>

這里我自定義了一個名叫 onceClick 的指令,給一個 button 按鈕加上這個指令之后,可以設置這個 button 按鈕在點擊多久之后,處于禁用狀態,防止用戶重復點擊。

小伙伴們看,這個指令的執行邏輯其實很簡單,el 相當于添加了這個指令的元素,監聽該元素的點擊事件,如果點擊該元素時,該元素不是處于禁用狀態,那么就設置該元素為禁用,給一個定時任務,到期后使該元素變為可用。這里邊具體的參數,松哥下面會跟大家詳細介紹。

不過這只是一個局部指令,只能在當前 .vue 文件中使用,我們也可以定義全局指令,這樣就可以在所有的 .vue 文件中使用了。

2.1.2 全局指令

全局指令我們一般寫在 main.js 中,或者寫一個單獨的 js 文件然后在 main.js 中引入,下面的例子是直接寫在 main.js 中:

const app = createApp(App);

app.directive('onceClick',{
mounted(el, binding, vnode) {
el.addEventListener('click', () => {
if (!el.disabled) {
el.disabled = true;
setTimeout(() => {
el.disabled = false;
}, binding.value || 1000);
}
});
}
})

這樣,我們就可以隨時隨地去使用 v-onceClick 這個指令了。

可能小伙伴感覺比較疑惑,自定義指令時候的 mounted 以及這里的參數都是咋回事,那么接下來松哥就來和大家詳細介紹一下這些方法和參數。

2.2 七個鉤子函數

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

  • created:在綁定元素的 attribute 或事件監聽器被應用之前調用。在指令需要附加在普通的 v-on 事件監聽器調用前的事件監聽器中時,這很有用。
  • beforeMount:當指令第一次綁定到元素并且在掛載父組件之前調用。
  • mounted:在綁定元素的父組件被掛載后調用,大部分自定義指令都寫在這里。
  • beforeUpdate:在更新包含組件的 VNode 之前調用。
  • updated:在包含組件的 VNode 及其子組件的 VNode 更新后調用。
  • beforeUnmount:在卸載綁定元素的父組件之前調用
  • unmounted:當指令與元素解除綁定且父組件已卸載時,只調用一次。

雖然鉤子函數比較多,看著有點唬人,不過我們日常開發中用的最多的其實是 mounted 函數。

2.3 四個參數

這里七個鉤子函數,鉤子函數中有回調參數,回調參數有四個,含義基本上和 Vue2 一致:

  • el:指令所綁定的元素,可以用來直接操作 DOM,我們松哥說想實現一個可以自動判斷組件顯示還是隱藏的指令,那么就可以通過 el 對象來操作 DOM 節點,進而實現組件的隱藏。
  • binding:我們通過自定義指令傳遞的各種參數,主要存在于這個對象中,該對象屬性較多,如下屬性是我們日常開發使用較多的幾個:

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

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

expression:字符串形式的指令表達式。例如 v-my-directive="1 + 1" 中,表達式為 "1 + 1"。

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

  • vnode:Vue 編譯生成的虛擬節點。
  • oldVnode:上一個虛擬節點,僅在 update 和 componentUpdated 鉤子中可用。

除了 el 之外,其它參數都應該是只讀的,切勿進行修改。如果需要在鉤子之間共享數據,建議通過元素的 dataset 來進行。

2.4 動態參數

有一種動態參數,這里也和小伙伴們分享下。正常情況下,我們自定義指令時傳遞的參數都是通過 binding.value 來獲取到的,不過在這之外還有一種方式就是通過 binding.arg 獲取參數。

我舉一個簡單例子,假設我們上面這個 onceClick 指令,默認的時間單位時毫秒,假設現在想給時間設置單位,那么我們就可以這樣寫:

const app = createApp(App);

app.directive('onceClick',{
mounted(el, binding, vnode) {
el.addEventListener('click', () => {
if (!el.disabled) {
el.disabled = true;
let time = binding.value;
if (binding.arg == "s") {
time = time * 1000;
}
setTimeout(() => {
el.disabled = false;
}, time);
}
});
}
})

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

<button v-onceClick:[timeUnit]="10" @click="btnClick">ClickMe</button>
<script>

import {ref} from 'vue';

export default {
name: "MyVue01",
setup() {
const timeUnit = ref('s');
return {timeUnit}
}
}
</script>

timeUnit 是一個提前定義好的變量。

3. 自定義權限指令

好啦,有了上面的基礎知識,接下來就來看我們本文的主題,自定義權限指令,我寫一個簡單的例子大家來看下:

const usersPermissions = ['user'];

app.directive('hasPermission', {
mounted(el, binding, vnode) {
const {value} = binding;
let f = usersPermissions.some(p => {
return p.indexOf(value) !== -1;
});
if (!f) {
el.parentNode && el.parentNode.removeChild(el);
}
}
})

usersPermissions 表示當前用戶所具備的權限,正常該數據應該是從服務端加載而來,但是我這里簡單起見,就直接定義好了。

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

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

<button @click="btnClick" v-hasPermission="['user:delete']">刪除用戶</button>

責任編輯:武曉燕 來源: 江南一點雨
相關推薦

2022-08-01 11:41:00

Vue插件

2022-05-11 10:45:21

SpringMVC框架Map

2021-11-30 08:19:43

Vue3 插件Vue應用

2023-06-28 08:05:46

場景vue3自定義

2022-03-24 15:28:43

Vue開發框架

2023-07-30 15:11:03

Vue3第三方組件庫

2009-06-02 15:38:36

eclipse streclipse開發steclipse str

2023-05-29 09:37:17

Vue3Vite

2011-05-03 15:59:00

黑盒打印機

2025-05-07 00:31:30

2011-01-10 14:41:26

2021-07-14 09:00:00

JavaFX開發應用

2020-06-01 16:25:43

WindowsLinux命令

2011-02-22 13:46:27

微軟SQL.NET

2021-02-26 11:54:38

MyBatis 插件接口

2021-12-28 08:38:26

Linux 中斷喚醒系統Linux 系統

2023-04-26 12:46:43

DockerSpringKubernetes

2022-12-07 08:42:35

2022-03-14 14:47:21

HarmonyOS操作系統鴻蒙

2022-07-27 08:16:22

搜索引擎Lucene
點贊
收藏

51CTO技術棧公眾號

一个色综合网| 成人爱爱网址| 成人深夜福利app| 国内精品久久影院| 亚州av综合色区无码一区| 麻豆网站免费在线观看| 成人av网站免费观看| 日韩av电影手机在线| 手机av在线不卡| 蜜桃在线一区| 91高清视频在线| 在线观看日韩片| 色婷婷视频在线| 日本亚洲三级在线| 欧美激情一级二级| 精品国产aaa| 亚洲精品a区| 欧美在线|欧美| 精品久久久无码人妻字幂| 偷拍25位美女撒尿视频在线观看| 久久精品一区二区国产| 久久色在线播放| 欧美一区二区免费在线观看| 精品成人免费一区二区在线播放| 夜夜揉揉日日人人青青一国产精品| 精品无码久久久久国产| 91女人18毛片水多国产| 99在线精品视频在线观看| 丝袜亚洲欧美日韩综合| avtt香蕉久久| 另类视频一区二区三区| 在线一区二区视频| 日韩一级性生活片| 欧美成人性生活视频| 成人免费高清在线| 成人免费淫片视频软件| 男人天堂av在线播放| 红桃视频国产一区| 久久久99久久精品女同性| 熟女少妇一区二区三区| 给我免费播放日韩视频| 欧美美女黄视频| 亚洲成熟丰满熟妇高潮xxxxx| 亚洲国产精品精华素| 中文字幕乱码一区二区免费| 蜜桃成人免费视频| 国产综合无码一区二区色蜜蜜| 精品一区二区在线观看| 国产成人免费91av在线| 羞羞影院体验区| 国产精品久久| 九九热在线精品视频| 日本黄色录像视频| 日韩国产一区二区三区| 亚洲人成啪啪网站| 亚洲国产欧美视频| 久9re热视频这里只有精品| 日韩一区二区影院| 一级网站在线观看| 国产精品国产三级在线观看| 欧美酷刑日本凌虐凌虐| 欧美大片久久久| 亚洲色图综合| 在线不卡a资源高清| 在线观看国产一级片| 国产精品成人国产| 欧美日本在线播放| 91 视频免费观看| 国产成人免费视频网站视频社区| 欧美精品 国产精品| 国产日韩欧美久久| 4438五月综合| 欧美一级精品在线| 亚洲色图欧美另类| 欧美电影在线观看免费| 国产丝袜一区视频在线观看| 欧美图片一区二区| 欧美综合一区| 北条麻妃一区二区三区中文字幕| 国产精品国产三级国产传播| 自拍偷拍欧美视频| 久久爱一区二区| 精品人妻一区二区三区潮喷在线| 欧美色一级片| 久久久久久久久久久免费精品| 国产一级二级毛片| 国产欧美二区| 国产激情综合五月久久| 亚洲一区精品在线观看| 国产盗摄一区二区三区| 九九九九精品| jizz日韩| 亚洲情趣在线观看| 亚洲 欧美 日韩 国产综合 在线| 在线观看的黄色| 精品视频免费在线| www.美色吧.com| 国产精品亚洲人成在99www| 中文字幕亚洲自拍| 久草视频免费播放| 丝袜美腿亚洲色图| 18成人在线| 日本福利午夜视频在线| 国产精品国产自产拍高清av| 日本男女交配视频| 91精品韩国| 日韩一区二区在线看| 丰满少妇一区二区| 永久亚洲成a人片777777| 午夜精品一区二区三区av| 一级久久久久久| 国产精品一区在线观看乱码 | 不卡av在线网| 亚洲精品高清视频| 华人av在线| 欧美二区三区91| 大地资源二中文在线影视观看| 久久福利综合| 国产91|九色| 国产wwwwwww| 中文字幕乱码一区二区免费| av在线播放亚洲| 日韩黄色三级在线观看| 亚洲免费视频在线观看| 真实国产乱子伦对白在线| 日韩精品一卡二卡三卡四卡无卡| 97久草视频| 午夜不卡视频| 欧美综合一区二区| v天堂中文在线| 中文在线日韩| 国产精品中文字幕久久久| 性插视频在线观看| 亚洲综合色成人| 日本黄色的视频| 精品久久久亚洲| 国产91精品黑色丝袜高跟鞋| 亚洲伦理在线观看| 亚洲欧洲另类国产综合| 香蕉视频网站入口| 欧美日韩播放| 青青草99啪国产免费| 蜜臀av免费在线观看| 亚洲女同ⅹxx女同tv| 日韩在线一区视频| 日韩av片子| 国产精品久久久久免费a∨ | 26uuu久久天堂性欧美| 91国在线高清视频| 国产精品1区| 爱福利视频一区| 亚洲网站免费观看| 国产精品家庭影院| 亚洲精品综合在线观看| 色婷婷色综合| 国产在线拍偷自揄拍精品| 91在线视频免费看| 欧美性大战久久久久久久蜜臀| 丰满少妇高潮一区二区| 久久国产精品久久久久久电车| 久久久www免费人成黑人精品| wwww亚洲| 91色婷婷久久久久合中文| 欧美色综合久久| 7777精品伊人久久久大香线蕉经典版下载| 亚洲一级Av无码毛片久久精品| 欧美fxxxxxx另类| 51国偷自产一区二区三区| 男人天堂综合| 欧美特黄一级| 5g国产欧美日韩视频| 羞羞视频在线观看免费| 日韩欧美国产综合一区| 欧美日韩偷拍视频| 国产·精品毛片| av日韩一区二区三区| 日韩精品欧美大片| 国产精品久久色| 黄av在线免费观看| 日韩精品一区二区三区视频在线观看 | 伊人久久在线| 综合136福利视频在线| 国产又大又粗又长| 亚洲一区二区偷拍精品| 中文字幕免费在线播放| 久久一二三四| 中文字幕乱码一区二区三区| 无码国模国产在线观看| 69国产精品成人在线播放| 巨骚激情综合| 欧美一区日本一区韩国一区| 日韩乱码人妻无码中文字幕| 久久久精品免费免费| 色一情一区二区| 国产精品地址| 日韩精品一区二区三区四区五区| 日韩在线你懂得| 国精产品一区一区三区有限在线| 三级理论午夜在线观看| 欧美精品精品一区| 黄色激情视频在线观看| 国产精品欧美极品| 黄色在线免费播放| 蜜臀av在线播放一区二区三区| 激情视频小说图片| 中文字幕中文字幕精品| 91中文精品字幕在线视频| 国模精品视频| 久久精品国产免费观看| 日夜干在线视频| 日韩一级黄色片| 天天爱天天做天天爽| 亚洲综合男人的天堂| 亚洲色图欧美色| 不卡的av电影| 韩国三级丰满少妇高潮| 丝袜亚洲另类丝袜在线| 成人网站免费观看入口| 91综合网人人| 日本精品视频一区| 亚洲精品aⅴ| 成人天堂噜噜噜| 成人天堂yy6080亚洲高清| 欧美国产精品va在线观看| 91高清在线| 亚洲欧美日韩精品久久亚洲区| 国内精品久久久久久久久久久| 在线免费精品视频| 国产成人无码一区二区三区在线| 中文字幕一区二区日韩精品绯色| 亚洲色图14p| 成人午夜在线免费| 国产又粗又猛又爽又黄| 久久成人麻豆午夜电影| 国产精品第12页| 亚洲免费综合| 国产精品999视频| 红桃视频国产精品| 日韩欧美一级在线| 91九色精品国产一区二区| 少妇精品久久久久久久久久| 日韩欧美影院| 久久涩涩网站| 欧美久久精品| 精品毛片久久久久久| 波多野结衣一区二区三区免费视频| 成人国产精品av| 日韩国产一二三区| 国产欧美日韩精品丝袜高跟鞋| 日本欧美韩国| 国产精品第一第二| 美女网站视频一区| 国产福利成人在线| 日韩电影av| 欧美最近摘花xxxx摘花| 少妇淫片在线影院| 欧美与黑人午夜性猛交久久久| av福利在线导航| 欧美激情欧美激情| 丰满大乳少妇在线观看网站| 欧美另类xxx| 羞羞的视频在线观看| 欧美第一黄网免费网站| 毛片网站在线看| 国内精品400部情侣激情| 91吃瓜在线观看| 97视频在线免费观看| 欧美xxxhd| 日韩av日韩在线观看| abab456成人免费网址| 国产欧美精品久久久| 欧美性www| 91精品久久久久久蜜桃| xvideos.蜜桃一区二区| 国产综合第一页| 国产精品片aa在线观看| 亚洲三区在线观看| 午夜欧美精品| 啊啊啊一区二区| 日韩不卡免费视频| 欧美性猛交xx| 99久久国产综合精品色伊| 日本黄色网址大全| 国产精品高潮呻吟久久| 欧美日韩在线观看成人| 黄色精品在线看| 区一区二在线观看| 555www色欧美视频| 人人妻人人澡人人爽人人欧美一区| 日韩精品视频在线播放| 国产小视频在线观看| 久久亚洲成人精品| 理论不卡电影大全神| 国产精品视频区| 99re8这里有精品热视频8在线| 国产一级精品aaaaa看| 精品久久久久久久| 加勒比成人在线| 日韩精品国产欧美| www.四虎精品| 国产亚洲短视频| 日本aⅴ在线观看| 欧美日韩在线影院| 国产精品无码免费播放| 日韩精品在线免费播放| 麻豆网站在线| 91精品国产乱码久久久久久久久| 成人在线免费电影网站| 亚洲自拍欧美色图| 久久91精品| 毛片在线视频观看| 日本欧美久久久久免费播放网| 亚洲v在线观看| 亚洲国产成人私人影院tom| 国产真实乱人偷精品视频| 欧美日韩久久一区| 亚洲av毛片成人精品| 久久资源免费视频| 国产日韩另类视频一区| 高清国产在线一区| 国产精品伦理久久久久久| 国产成人无码a区在线观看视频| 蜜臂av日日欢夜夜爽一区| 人妻丰满熟妇av无码久久洗澡| 一区二区三区中文在线| 中文字幕久久熟女蜜桃| 日韩精品福利在线| 福利成人导航| 亚洲综合中文字幕68页| 精品免费一区二区| 日韩精品―中文字幕| 国产成人aaa| 一级片一级片一级片| 欧美在线免费观看亚洲| 日色在线视频| 69av视频在线播放| 久久99国产精品久久99大师| 男人日女人的bb| 韩国成人精品a∨在线观看| 亚洲ⅴ国产v天堂a无码二区| 欧美午夜精品久久久久久人妖 | 亚洲第一网站男人都懂| 菠萝蜜视频国产在线播放| 91精品国产综合久久香蕉| 欧美美女一区| 久草福利视频在线| 国产日韩欧美综合在线| aaa在线视频| 亚洲乱码av中文一区二区| 欧美男男tv网站在线播放| 好吊色欧美一区二区三区视频| 欧美日韩综合| 潘金莲一级淫片aaaaa| 亚洲激情第一区| 成 人片 黄 色 大 片| 欧美猛男性生活免费| 午夜久久av| 亚洲精品久久久久久久蜜桃臀| 国产不卡高清在线观看视频| 国产女人被狂躁到高潮小说| 7777精品伊人久久久大香线蕉的| 国精产品一区| 亚洲a成v人在线观看| 综合激情网站| 黑人玩弄人妻一区二区三区| 亚洲午夜免费电影| 婷婷开心激情网| 51色欧美片视频在线观看| 欧美日韩播放| 中文字幕成人在线视频| 亚洲私人黄色宅男| 精品国产九九九| 国内精品久久久久久久| 亚州综合一区| 少妇激情一区二区三区| 国产精品夫妻自拍| 99在线精品视频免费观看软件 | 成年人av电影| 日韩成人在线电影网| 天天综合网天天| 黄色一级视频播放| 99re8在线精品视频免费播放| 日韩美一区二区| 少妇精69xxtheporn| 永久免费精品视频| 日韩 欧美 高清| 亚洲天堂福利av| 日韩一区免费视频| 国产精品福利在线观看网址| 亚洲情侣在线| 天天插天天射天天干| 欧美妇女性影城| 蜜桃视频在线观看免费视频| 午夜欧美一区二区三区免费观看| 国产在线精品一区二区不卡了| 日韩av免费网址| 久久精品99国产精品酒店日本| 国产精品乱战久久久| 嫩草影院国产精品| 亚洲成人综合网站|