首頁 >web前端 >js教程 >內部自訂指令和全域自訂指令的實現

內部自訂指令和全域自訂指令的實現

巴扎黑
巴扎黑原創
2017-07-23 15:08:131440瀏覽

在Vue中,我們平時資料驅動視圖時候,內部自帶的指令有時候解決不了一些需求,這時候,Vue給我們一個很好用的東東

directive

這個字是我們寫自訂指令的關鍵字哦

#之定義指令為我們提供了幾個鉤子函數,這時候你一定好奇什麼是鉤子函數,說簡單點,就是集中表現狀態

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

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

  • update: 被綁定元素所在的範本更新時調用,而不論綁定值是否會改變。透過比較更新前後的綁定值,可以忽略不必要的模板更新(詳細的鉤子函數參數見下)。

  • componentUpdated: 被綁定元素所在範本完成一次更新週期時呼叫。

  • unbind: 只呼叫一次, 指令與元素解綁時呼叫。

下面我們開始上程式碼,讓我們更好的理解自訂指令怎麼做

##
<!DOCTYPE html><html lang="en"><head><meta charset="UTF-8"><title>Document</title><script src="https://unpkg.com/vue/dist/vue.js?1.1.11"></script></head><body><div id="app"><div class="ab" v-css="{&#39;color&#39;:&#39;red&#39;,&#39;font-size&#39;:&#39;30px&#39;}">hello</div><input type="text" v-focus></div>
 </body></html>
#在html中,我們看到了兩個指令v-css和v-focus

我們自訂指令時候,一定前面要帶上v-

Vue.directive("css",{//钩子函数 ,el就是当前元素    inserted(el,binding){//el绑定的元素本身//binding就是css指令里面的的对象元素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) {//指令绑定在元素上时候执行,只执行一次    }
});new Vue({
          el:'#app',
        data:{
            show:true},
        directives:{
        focus:{
            inserted(el,binding){//el绑定的元素本身//binding就是css指令里面的的对象元素                el.focus();
                }
            }
        }
    });
在js裡面我們可以看到

Vue.directive("css",{})

#我們在

new Vue外部定義了這樣一段程式碼,這就是我們全域自訂指令的範本方式

css是自訂指令的名字

{}裡面我們寫上鉤子函數就可以

我們所有的鉤子函數裡面,基本上都會有2個參數

el,binding

  • #el: 指令所綁定的元素,可以用來直接操作DOM 。

  • binding 綁定元素本身的一個物件

#從上面我們可以看到,binding裡面保留綁定指令的name和value,這些很重要

局部自訂指令

directives:{

name:{

}
}

差別在於,我們寫在new Vue裡面,裡面api操作和上面的全域自訂指令一樣

下面我們開始看程式碼運行結果

我們可以看到樣式引用上去了

文字方塊也取得了焦點

 

以上是內部自訂指令和全域自訂指令的實現的詳細內容。更多資訊請關注PHP中文網其他相關文章!

陳述:
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn