vue.js實現內部自定義指令和全局自定義指令------directive


在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"></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中,我們看到了兩個指令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操作和上面的全局自定義指令一樣

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

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

文本框也獲取了焦點

 


免責聲明!

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



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