Vue - 自定義指令


1、Vue.directive(id,definition)注冊一個全局自定義指令,接收兩個參數,指令ID以及定義對象

 

2、鈎子函數:將作用域與DOM進行鏈接,鏈接函數用來創建可以操作DOM的指令

bind - 只調用一次,在指令第一次綁定到元素上時候調用
update - 在bind之后立即以初始值為參數第一次調用,之后綁定值變化的時候,參數為新值與舊值
unbind - 只調用一次,在指令從元素上解綁的時候調用

-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------

-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------

Vue.directive('my-directive',{
    bind : function(){
        //准備工作
        //例如,添加事件處理器或只需要運行一次的高耗任務
    },

    update : function(){
        //值更新時的工作
        //也會以初始值為參數調用一次
    },

    unbind : function(){
        //清理工作
        //例如,刪除bind()添加的事件監聽器
    }
})

//調用
<div v-my-directive="someValue"></div>

//只需要update函數,可以傳一個函數替代定義對象
Vue.directive('my-directive',function(value){})

-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------

-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------

<!-- 如果指令需要多個值,可以傳入一個js對象 -->
<!-- 指令可以使用合法的js表達式 -->
<body id="example">
    <div id="demo" v-demo="{color : 'white',text : 'hello!'}"></div>
</body>
<script>
    Vue.directive('demo',function(value){
        console.info(value.color); //white
        console.info(value.text) // hello!
    })
    var demo = new Vue({
        el : '#demo'
    })
</script>

-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------

-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------

當指令使用字面修飾符,值將按普通字符串處理並傳遞給update方法,update方法只調用一次,因為普通字符串不能影響數據變化

<body id="example">
    <div id="demo" v-demo.literal="foo bar baz"></div>
</body>
<script>
    Vue.directive('demo',function(value){
        console.info(value); //foo bar baz
    })
    var demo = new Vue({
        el : '#demo'
    })
</script>

 

3、以屬性的形式使用自定義屬性

<body id="demo">
    <my-directive class="hello" name="hi"></my-directive>
</body>
<script type="text/javascript">
    Vue.elementDirective('my-directive',{
        //api同普通指令一致
        bind : function(){
            console.info(this.el.className);
            console.info(this.el.getAttribute('name'))
        }
    })

    var demo = new Vue({
        el : '#demo'
    })
</script>

-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------

-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------

<body id="demo">
    <my-directive class="hello" name="hi" a="params"></my-directive>
</body>
<script type="text/javascript">
    Vue.elementDirective('my-directive',{
        params : ['a'],

        //api同普通指令一致
        bind : function(){
            console.info(this.el.className);
            console.info(this.el.getAttribute('name'))
        }
    })

    var demo = new Vue({
        el : '#demo'
    })
</script>

<!-- 或者需要自動更新的時候,需要一個回調 -->
<body id="demo">
    <my-directive class="hello" name="hi" v-bind:a="someValue"></my-directive>
    <input type="text" v-model="someValue">
</body>
<script type="text/javascript">
    Vue.elementDirective('my-directive',{
        params : ['a'],

        paramWatchers : {
            a : function(val,oldValue){
                console.info('a changes');
            }
        }
    })

    var demo = new Vue({
        el : '#demo',
        data : {
            someValue : 'value'
        }
    })
</script>

 

4、自定義屬性用在對象上,對象內部屬性變化的時候觸發update,在指令定義對象中指定deep:true

<body id="demo">
    <div v-my-directive="a"></div>
    <button @click="change">change</button>{{a,b,c}}
</body>
<script>
    Vue.directive('my-directive',function(){
        deep : true,

        update : function(obj){
            //當obj的嵌套屬性變化時候調用
            console.info(obj.b.c);
        }
    })
    var demoVM = new Vue({
        el : '#demo',

        data : {
            a : {b : {c : 2}}
        },

        method : {
            change : function(){
                demoVM.a.b.c = 4;
            }
        }
    })
</script>

 

5、acceptStatement讓自定義指令接受內聯語句

<body id="demo">
    <div v-my-directive="a++"></div>
    {{a}}
</body>
<script>
    Vue.directive('my-directive',function(){
        acceptStatement : true,

        update : function(fn){
            //當obj的嵌套屬性變化時候調用
            console.info(fn.toString())
            fu();
        }
    })
    var demoVM = new Vue({
        el : '#demo',

        data : {
            a : 5
        }
    })
</script>

 

6、v-on綁定多個事件時,要是是不同的事件類型,例如點擊,focus,change,會按照業務需求進行選擇,要是綁定了2個甚至多個click事件,那么v-on只會綁定第一個click事件

 


免責聲明!

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



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