本文為大家分享了vue指令directive的使用方法,供大家參考,具體內(nèi)容如下
1.指令的注冊(cè)
指令跟組件一樣需要注冊(cè)才能使用,同樣有兩種方式,一種是全局注冊(cè):
Vue.directive('dirName',function(){  //定義指令});另外一種是局部注冊(cè):
new Vue({  directives:{    dirName:{      //定義指令    }  }});2.指令的定義
指令定義,官方提供了五個(gè)鉤子函數(shù)來(lái)供我們使用,分別代表了一個(gè)組件的各個(gè)生命周期
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)用,而不論綁定值是否變化。通過(guò)比較更新前后的綁定值,可以忽略不必要的模板更新(詳細(xì)的鉤子函數(shù)參數(shù)見(jiàn)下)。
componentUpdated: 被綁定元素所在模板完成一次更新周期時(shí)調(diào)用。
unbind: 只調(diào)用一次, 指令與元素解綁時(shí)調(diào)用。
在這里其他幾個(gè)都好理解,關(guān)于模板更新(update)這里,本人的理解是:該指令所在的模板有變化而需要重新渲染的時(shí)候,比如當(dāng)一個(gè)輸入框的model發(fā)生了變化就會(huì)觸發(fā)指令。當(dāng)然此處說(shuō)的比較模糊,具體的還有待研究。
這段代碼可以實(shí)現(xiàn)關(guān)于update的使用
<div id="app">  <input type="text" v-focus="name" v-model="name" :data-name="name">  <button type="button" @click="name='zw'">click</button>  <!--當(dāng)點(diǎn)擊按鈕的時(shí)候name改變,繼而觸發(fā)update中的方法--></div><script>  Vue.directive('focus',{    bind: function(el, binding){    console.log('bind:',binding.value);  },  inserted: function(el, binding){    console.log('insert:',binding.value);  },  update: function(el, binding, vnode, oldVnode){    el.focus();    console.log(el.dataset.name);//這里的數(shù)據(jù)是可以動(dòng)態(tài)綁定的    console.table({      name:binding.name,      value:binding.value,      oldValue:binding.oldValue,      expression:binding.expression,      arg:binding.arg,      modifiers:binding.modifiers,      vnode:vnode,      oldVnode:oldVnode    });  },  componentUpdated: function(el, binding){    console.log('componentUpdated:',binding.name);  }});new Vue({  el:'#app',  data:{    name:'zwzhai'  }});</script>3.鉤子函數(shù)的定義
以下是官方提供的幾個(gè)參數(shù):
	el: 指令所綁定的元素,可以用來(lái)直接操作 DOM 。
	binding: 一個(gè)對(duì)象,包含以下屬性:
	name: 指令名,不包括 v- 前綴。
	value: 指令的綁定值, 例如: v-my-directive="1 + 1", value 的值是 2。
	oldValue: 指令綁定的前一個(gè)值,僅在 update 和 componentUpdated 鉤子中可用。無(wú)論值是否改變都可用。
	expression: 綁定值的字符串形式。 例如 v-my-directive="1 + 1" , expression 的值是 "1 + 1"。
	arg: 傳給指令的參數(shù)。例如 v-my-directive:foo, arg 的值是 "foo"。
	modifiers: 一個(gè)包含修飾符的對(duì)象。 例如: v-my-directive.foo.bar, 修飾符對(duì)象 modifiers 的值是{ foo: true, bar: true }。
	vnode: Vue 編譯生成的虛擬節(jié)點(diǎn),查閱 VNode API 了解更多詳情。
	oldVnode: 上一個(gè)虛擬節(jié)點(diǎn),僅在 update 和 componentUpdated 鉤子中可用。
這幾個(gè)參數(shù),大家看文檔也能理解,就不多說(shuō)了,關(guān)于bingding的幾個(gè)屬性說(shuō)一下自己的看法,value這個(gè)屬性,可以傳字面量,也可以傳單條語(yǔ)句(如上),還可以以變量的形式如<input type="text" v-focus="name" v-model="name">;arg這里可以傳一個(gè)字符串,因?yàn)樵趘alue去訪問(wèn)綁定值得時(shí)候拿到的不是直接寫(xiě)的那個(gè),也就是說(shuō)v-focus="name",這個(gè)name永遠(yuǎn)都是一個(gè)變量,需要定義賦值,而arg可以直接訪問(wèn)該值,如v-focus:foo,那么在鉤子函數(shù)中拿到的就是foo這個(gè)字符串。
在vue的指令中是不可以雙向數(shù)據(jù)綁定的,如官方所說(shuō):除了 el 之外,其它參數(shù)都應(yīng)該是只讀的,盡量不要修改他們。如果需要在鉤子之間共享數(shù)據(jù),建議通過(guò)元素的 dataset 來(lái)進(jìn)行。這里補(bǔ)充下關(guān)于dataset的知識(shí):
data- 是html5的一個(gè)新屬性,查了下瀏覽器支持程度,目前的主流瀏覽器都是支持的,IE的話要到10以上。具體的使用:在HTML中以屬性的方式去寫(xiě),data-yourname="value",在js中取這個(gè)屬性就不用使用getAttribute這個(gè)方法,而是直接訪問(wèn),ele.dataset.yourname,在js中你也可以添加和刪除,添加:ele.dataset.dessert="yourname",刪除:dette ele.dataset.name。此外,這個(gè)屬性可以用作css選擇器:.class[data-name]:{}。
最后附上自己寫(xiě)的一個(gè)vue小程序,簡(jiǎn)單的頁(yè)面切換,使用vue-cli構(gòu)建,sample的簡(jiǎn)單版,還使用的mint-ui組件庫(kù),git地址:https://github.com/Stevenzwzhai/news-vue
以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持VeVb武林網(wǎng)。
新聞熱點(diǎn)
疑難解答