vue.js內(nèi)部自定義指令與全局自定義指令的實(shí)現(xiàn)詳解(利用directive)
前言
大家都知道在Vue中,我們平時(shí)數(shù)據(jù)驅(qū)動(dòng)視圖時(shí)候,內(nèi)部自帶的指令有時(shí)候解決不了一些需求,這時(shí)候,Vue給我們一個(gè)很好用的東東來實(shí)現(xiàn)自定義指令,這就是directive。下面話不多說了,來一起看看詳細(xì)的介紹:
directive
這個(gè)單詞是我們寫自定義指令的關(guān)鍵字哦
自定義指令為我們提供了幾個(gè)鉤子函數(shù),這時(shí)候你一定好奇什么是鉤子函數(shù),說簡單點(diǎn),就是集中表現(xiàn)狀態(tài)
- bind: 只調(diào)用一次,指令第一次綁定到元素時(shí)調(diào)用,用這個(gè)鉤子函數(shù)可以定義一個(gè)在綁定時(shí)執(zhí)行一次的初始化動(dòng)作。
- inserted: 被綁定元素插入父節(jié)點(diǎn)時(shí)調(diào)用(父節(jié)點(diǎn)存在即可調(diào)用,不必存在于 document 中)。
- update: 被綁定元素所在的模板更新時(shí)調(diào)用,而不論綁定值是否變化。通過比較更新前后的綁定值,可以忽略不必要的模板更新(詳細(xì)的鉤子函數(shù)參數(shù)見下)。
- componentUpdated: 被綁定元素所在模板完成一次更新周期時(shí)調(diào)用。
- unbind: 只調(diào)用一次, 指令與元素解綁時(shí)調(diào)用。
下面我們開始上代碼,讓我們更好的理解自定義指令怎么做
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<title>Document</title>
<script src="https://unpkg.com/vue/dist/vue.js"></script>
</head>
<body>
<div id="app">
<div class="ab" v-css="{'color':'red','font-size':'30px'}">
hello
</div>
<input type="text" v-focus>
</div>
</body>
</html>
在html中,我們看到了兩個(gè)指令v-css和v-focus
我們自定義指令時(shí)候,一定前面要帶上v-
Vue.directive("css",{
//鉤子函數(shù) ,el就是當(dāng)前元素
inserted(el,binding){
//el綁定的元素本身
//binding就是css指令里面的的對(duì)象元素
let styleobj=binding.value,arr=[];
for(let key in styleobj){
arr.push(key+":"+styleobj[key])
}
arr=arr.join(";");
el.style.cssText=arr;
},
bind(el,binding) {
//指令綁定在元素上時(shí)候執(zhí)行,只執(zhí)行一次
}
});
new Vue({
el:'#app',
data:{
show:true
},
directives:{
focus:{
inserted(el,binding){
//el綁定的元素本身
//binding就是css指令里面的的對(duì)象元素
el.focus();
}
}
}
});
在js里面我們可以看到
Vue.directive("css",{})
我們?cè)?new Vue外部定義了這樣一段代碼,這就是我們?nèi)肿远x指令的模板方式
- css是自定義指令的名字
- {}里面我們寫上鉤子函數(shù)就可以
我們所有的鉤子函數(shù)里面,基本都會(huì)有2個(gè)參數(shù)el,binding
- el: 指令所綁定的元素,可以用來直接操作 DOM 。
- binding 綁定元素本身的一個(gè)對(duì)象

從上面我們可以看到,binding里面保留綁定指令的name和value,這些很重要
局部自定義指令
directives:{
name:{
}
}
區(qū)別在于,我們寫在new Vue里面,里面api操作和上面的全局自定義指令一樣
下面我們開始看代碼運(yùn)行結(jié)果

我們可以看到樣式引用上去了
文本框也獲取了焦點(diǎn)
總結(jié)
以上就是這篇文章的全部內(nèi)容了,希望本文的內(nèi)容對(duì)大家的學(xué)習(xí)或者工作能帶來一定的幫助,如果有疑問大家可以留言交流,謝謝大家對(duì)腳本之家的支持。
相關(guān)文章
vue項(xiàng)目優(yōu)化之通過keep-alive數(shù)據(jù)緩存的方法
本篇文章主要介紹了vue項(xiàng)目優(yōu)化之通過keep-alive數(shù)據(jù)緩存的方法,小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧2017-12-12
Vue數(shù)據(jù)監(jiān)聽方法watch的使用
這篇文章主要介紹了Vue數(shù)據(jù)監(jiān)聽方法watch的使用,小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧2018-03-03
vue自定義指令實(shí)現(xiàn)元素滑動(dòng)移動(dòng)端適配及邊界處理
這篇文章主要為大家介紹了vue自定義指令實(shí)現(xiàn)元素滑動(dòng)移動(dòng)端適配及邊界處理詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2022-09-09
vue?element-ui動(dòng)態(tài)橫向統(tǒng)計(jì)表格的實(shí)現(xiàn)
這篇文章主要介紹了vue?element-ui動(dòng)態(tài)橫向統(tǒng)計(jì)表格的實(shí)現(xiàn)方式,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2022-08-08
vue2.0使用swiper組件實(shí)現(xiàn)輪播的示例代碼
下面小編就為大家分享一篇vue2.0使用swiper組件實(shí)現(xiàn)輪播的示例代碼,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過來看看吧2018-03-03

