第一章 Vue核心 第十六节 自定义指令

需求1:定义一个v-big指令,和v-text指令功能类似,但会把绑定的数值放大10倍
需求2:定义一个v-fbind指令,和v-bind功能类似,但可以让其所绑定的input元素默认获取焦点

自定义指令总结:
    一、定义语法:
        (1).局部指令:
            new Vue({                                    new Vue({
                directives:{指令名:配置对象}       或           directives:{指令名:回调函数}
            });                                          });
        (2).全局指令:
            Vue.directive(指令名,配置对象)    或    Vue.directive(指令名,回调函数)

    二、配置对象中常用的3个回调:
        (1).bind:指令与元素成功绑定时调用
        (2).inserted:指令所在元素被插入页面时调用
        (3).update:指令所在模板结构被重新解析时调用

    三、备注:
        1.指令定义不加v-,但使用时要加v-
        2.指令名如果是多个单词,要使用kebab-case命名方式,不要使用camelCase命名

示例代码:

复制代码
<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>自定义指令</title>
    <script src="../lib/vue.js"></script>
    <link rel="stylesheet" href="../../鼠标指针样式.css"/>
</head>
<body>
    <div id="root">
        <h2>当前的number值是:<span v-text="number"></span></h2>
        <h2>放大10倍后的number值是:<span v-big="number"></span></h2>
        <!--<h2>放大10倍后的number值是:<span v-big-number="number"></span></h2>-->
        <button @click="number++">n+1</button>
        <hr/>

        <input type="text" v-fbind:value="number" />
        <!--全局指令-->
        <input type="text" v-my-dir:value="number" />

    </div>
    <script type="text/javascript">
        Vue.config.productionTip = false;

        //定义全局指令
        Vue.directive('my-dir',{                         //'my-dir',function(element,binding){}
            //指令与元素成功绑定时
            bind(element,binding){
                element.value = binding.value;
                console.log('bind');
            },
            //指令所在的元素被插入页面时
            inserted(element,binding){
                element.focus();
                console.log('inserted');
            },
            //指令所在的模板重新解析时
            update(element,binding){
                element.value = binding.value;
                console.log('update');
            }
        });

        new Vue({
            el:'#root',
            data:{
                number:1
            },
            directives:{
                //big函数何时会被调用?1.指令与元素成功绑定时;2.指令所在的模板重新解析时
                big(element,binding){
                    console.log('this ---> ',this);//此处的this是Window
                    element.innerText = binding.value*10;
                    console.log(element,binding);
                },
                // 'big-number'(element,binding){              //或者 'big-number':function(){}
                //     element.innerText = binding.value*10;
                //     console.log(element,binding);
                // },
                //
                fbind:{
                    //指令与元素成功绑定时
                    bind(element,binding){
                        element.value = binding.value;
                        console.log('bind');
                    },
                    //指令所在的元素被插入页面时
                    inserted(element,binding){
                        element.focus();
                        console.log('inserted');
                    },
                    //指令所在的模板重新解析时
                    update(element,binding){
                        element.value = binding.value;
                        console.log('update');
                    }
                }
            }
        });
    </script>
</body>
</html>
复制代码

本文作者:何以之

本文链接:https://www.cnblogs.com/serendipity-echo/articles/15408222.html

版权声明:本作品采用知识共享署名-非商业性使用-禁止演绎 2.5 中国大陆许可协议进行许可。

posted @   何以之  阅读(41)  评论(0编辑  收藏  举报
点击右上角即可分享
微信分享提示
评论
收藏
关注
推荐
深色
回顶
收起
  1. 1 残酷游戏 卫兰
  2. 2 明知做戏 吴雨霏
  3. 3 你,好不好? 周兴哲
  4. 4 我可以 蔡旻佑
  5. 5 云烟成雨 房东的猫
  6. 6 说散就散 JC 陈咏桐
  7. 7 我配不上你 夏天Alex
  8. 8 不再联系 夏天Alex
  9. 9 等我先说 夏天Alex
  10. 10 我知道他爱你 夏天Alex
  11. 11 多想在平庸的生活拥抱你 隔壁老樊
  12. 12 这一生关于你的风景 隔壁老樊
  13. 13 我曾 隔壁老樊
  14. 14 关于孤独我想说的话 隔壁老樊
  15. 15 过客 周思涵
  16. 16 备爱 周思涵
  17. 17 嚣张 en
  18. 18 海口 后弦
明知做戏 - 吴雨霏
00:00 / 00:00
An audio error has occurred, player will skip forward in 2 seconds.

作词 : 夏至(蔡冕丽)

作曲 : 方文良

编曲 : 吴国恩

等你的汽水喝一半给你加片薄冰

等你的桌面满泄我总会打理重整

不想纯情

不够聪明

你未发现我的身影

得我帮你依照编码整理家里电影

只会得我一个帮你选购喜爱铃声

天天如常

估你心情

等一个眼神求证

一闪擦过如流星

怎么我为我做过的感到惊怕

就像爱吗我也不肯定恐怕

我以为存在吗

千变万化

从来不肯开口可相信吗

离谱吗

请你不要阻我喜欢你

明明是爱但你未说话你扮作闪避

这个沉默冷静的你亳无办法处理

其实我亦怕是错摸心理

总有天会等到好天气

游行示爱大叫着你在某大遍草地

等你无用退避不过仍然害羞的你

还是顾忌太不争气

明知做戏

即使你未太在意不感到惊讶

现在要说爱你请准备招架

勇气还存在吗

不要害怕

随时真的胆敢亲手送花

离谱吗

请你不要阻我喜欢你

明明是爱但你未说话你扮作闪避

这个沉默冷静的你亳无办法处理

其实我亦怕是错摸心理

总有天会等到好天气

游行示爱大叫着你在某大遍草地

等你无用退避不过仍然害羞的你

还是顾忌太不争气

明知做戏

不过不要阻我紧张你

如何令你愉快让我办妥为你准备

喜爱沉默冷静的你还是自信的你

仍愿意为你造一些惊喜

总有天会等到好天气

游行示爱大叫着你在某大遍草地

等你无用退避不过途人目光不理

期待贴着你的手臂

无须做戏

等你喜爱等你不爱就凭摘毫验证

想爱不爱偏爱不理亦同样难划清

天天如常

估你心情

不想扑索来求证

争取过趁还年青

终于你下决定来答应

太动听