【vue開發】vue指令Vue.directive使用教程


1.指令的注冊

指令跟組件一樣需要注冊才能使用,同樣有兩種方式,一種是全局注冊:

?
1
2
3
4
5
Vue.directive( 'dirName' , function (){
 
   //定義指令
 
});

另外一種是局部注冊:

?
1
2
3
4
5
6
7
8
9
10
11
12
13
new Vue({
 
  directives:{
 
    dirName:{
 
       //定義指令
 
    }
 
  }
 
});

2.指令的定義

指令定義,官方提供了五個鈎子函數來供我們使用,分別代表了一個組件的各個生命周期

bind: 只調用一次,指令第一次綁定到元素時調用,用這個鈎子函數可以定義一個在綁定時執行一次的初始化動作。

inserted: 被綁定元素插入父節點時調用(父節點存在即可調用,不必存在於 document 中)。

update: 被綁定元素所在的模板更新時調用,而不論綁定值是否變化。通過比較更新前后的綁定值,可以忽略不必要的模板更新(詳細的鈎子函數參數見下)。

componentUpdated: 被綁定元素所在模板完成一次更新周期時調用。

unbind: 只調用一次, 指令與元素解綁時調用。

在這里其他幾個都好理解,關於模板更新(update)這里,本人的理解是:該指令所在的模板有變化而需要重新渲染的時候,比如當一個輸入框的model發生了變化就會觸發指令。當然此處說的比較模糊,具體的還有待研究。

這段代碼可以實現關於update的使用

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
< div id = "app" >
  < input type = "text" v-focus = "name" v-model = "name" :data-name = "name" >
  < button type = "button" @ click = "name='zw'" >click</ button >
 
   <!--當點擊按鈕的時候name改變,繼而觸發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);//這里的數據是可以動態綁定的
    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.鈎子函數的定義

以下是官方提供的幾個參數:

el: 指令所綁定的元素,可以用來直接操作 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這個屬性,可以傳字面量,也可以傳單條語句(如上),還可以以變量的形式如<input type="text" v-focus="name" v-model="name">;arg這里可以傳一個字符串,因為在value去訪問綁定值得時候拿到的不是直接寫的那個,也就是說v-focus="name",這個name永遠都是一個變量,需要定義賦值,而arg可以直接訪問該值,如v-focus:foo,那么在鈎子函數中拿到的就是foo這個字符串。

在vue的指令中是不可以雙向數據綁定的,如官方所說:除了 el 之外,其它參數都應該是只讀的,盡量不要修改他們。如果需要在鈎子之間共享數據,建議通過元素的 dataset 來進行。這里補充下關於dataset的知識:

data-  是html5的一個新屬性,查了下瀏覽器支持程度,目前的主流瀏覽器都是支持的,IE的話要到10以上。具體的使用:在HTML中以屬性的方式去寫,data-yourname="value",在js中取這個屬性就不用使用getAttribute這個方法,而是直接訪問,ele.dataset.yourname,在js中你也可以添加和刪除,添加:ele.dataset.dessert="yourname",刪除:dette ele.dataset.name。此外,這個屬性可以用作css選擇器:.class[data-name]:{}。

使用示例:

組件中使用方法:

app.vue中注冊:

全局主題變量:


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM