本文為大家分享了vue指令directive的使用方法,供大家參考,具體內容如下
1.指令的註冊
指令跟組件一樣需要註冊才能使用,同樣有兩種方式,一種是全局註冊:
Vue.directive('dirName',function(){ //定义指令 });
另外一種是局部註冊:
new Vue({ directives:{ dirName:{ //定义指令 } } });
2.的各個生命週期
bind: 只調用一次,指令第一次綁定到元素時調用,用這個鉤子函數可以定義一個在綁定時執行一次的初始化動作。
inserted: 被綁定元素插入父節點時調用(父節點存在即可調用,不必存在於 document 中)。
update: 被綁定元素所在的模板更新時調用,而不論綁定值是否變化。透過比較更新前後的綁定值,可以忽略不必要的模板更新(詳細的鉤子函數參數見下)。
componentUpdated: 被綁定元素所在模板完成一次更新周期時呼叫。
unbind: 只呼叫一次, 指令與元素解綁時呼叫。
在這裡其他幾個都好理解,關於模板更新(update)這裡,本人的理解是:該指令所在的模板有變化而需要重新渲染的時候,比如當一個輸入框的model發生了變化就會觸發指令。當然此處說的比較模糊,具體的還有待研究。
這段程式碼可以實現關於update的使用
<p id="app"> <input type="text" v-focus="name" v-model="name" :data-name="name"> <button type="button" @click="name='zw'">click</button> <!--当点击按钮的时候name改变,继而触发update中的方法--> </p> <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);//这里的数据是可以动态绑定的 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.鉤子函數的定義
以下是官方提供的幾個參數:
直接操作DOM 。binding: 一個對象,包含以下屬性:
name: 指令名,不包含 v- 前綴。value: 指令的綁定值, 例如: v-my-directive="1 + 1", value 的值是 2。
oldValue: 指令綁定的前一個值,僅在 update 和 componentUpdated 鉤子中可用。無論值是否改變都可用。
expression: 綁定值的字串形式。 例如 v-my-directive="1 + 1" , expression 的值是 "1 + 1"。
arg: 傳給指令的參數。例如 v-my-directive:foo, arg 的值是 "foo"。
modifiers: 一個包含修飾符的物件。 例如: v-my-directive.foo.bar, 修飾符物件 modifiers 的值是{ foo: true, bar: true }。
vnode: Vue 編譯產生的虛擬節點,查閱 VNode API 以了解更多詳情。
oldVnode: 上一個虛擬節點,僅在 update 和 componentUpdated 鉤子中可用。
這幾個參數,大家看文檔也能理解,就不多說了,關於bingding的幾個屬性說一下自己的看法,value這個屬性,可以傳字面量,也可以傳單條語句(如上) ,也可以以變數的形式如;arg這裡可以傳一個字串,因為在value去存取綁定值得時候拿到的不是直接寫的那個,也就是說v-focus="name",這個name永遠都是一個變量,需要定義賦值,而arg可以直接訪問該值,如v-focus:foo,那麼在鉤子函數中拿到的就是foo這個字串。