Vue.directive使用注意

2019-10-19 16:35:45

参考地址 Vue.directive使用注意

首先,Vue.directive要在实例初始化之前,不然会报错,还有,定义的指令不支持驼峰式写法,也会报下面同样的错,虽然在源码中没有找到在哪里统一处理大小写,但是在有关directive的方法中捕捉到的指令命名统一变为小写,所以,还是用'-'或者'_'分割吧。

vue.js:491 [Vue warn]: Failed to resolve directive: xxx

然后,其定义方式有两种,一种是Vue.directive('xxx', function(el, bind, vNode){}),其中el为dom,vNode为vue的虚拟dom,bind为一较复杂对象,详情可见Vue-directive钩子函数中的参数的参数,还有一种,为

Vue.directive('my-directive', {
  bind: function () {},
  inserted: function () {},
  update: function () {},
  componentUpdated: function () {},
  unbind: function () {}
})

参数代表的含义,参见钩子函数描述

最后,要使用自定义的指令,只需在对用的元素中,加上'v-'的前缀形成类似于内部指令'v-if','v-text'的形式。

// Vue.directive
            Vue.directive('test_directive', function(el, bind, vNode){
                el.style.color = bind.value;
            });            var app = new Vue({
                el: '#app',
                data: {
                    num: 10,
                    color: 'red'
                },
                methods: {
                    add: function(){                        this.num++;
                    }
                }
            });

当然,也可以将method中的方法加入,bind.value即为methods中的方法。

<div id="app">
            <div v-test_directive="changeColor">{{num}}</div>
            <button @click="add">增加</button>
        </div>

        <script type="text/javascript">
            // Vue.directive
            Vue.directive('test_directive', function(el, bind, vNode){
                el.style.color = bind.value();
            });            var app = new Vue({
                el: '#app',
                data: {
                    num: 10,
                    color: 'red'
                },
                methods: {
                    add: function(){                        this.num++;
                    },
                    changeColor: function(){                        return this.color;
                    }
                }
            });

这种形式,可以模仿'v-once',并进行一定的复杂逻辑,但是想要完全达到'v-once',可能需要考虑Vue-directive的钩子函数各个周期。下面是固定num的值,使得add的方法无效。

<div id="app">
            <div v-test_directive="changeColor">{{num}}</div>
            <button @click="add">增加</button>
        </div>

        <script type="text/javascript">
            // Vue.directive
            Vue.directive('test_directive', function(el, bind, vNode){
                el.style.color = bind.value();
            });            var app = new Vue({
                el: '#app',
                data: {
                    num: 10,
                    color: 'red'
                },
                methods: {
                    add: function(){                        this.num++;
                    },
                    changeColor: function(){                        this.num = 20;                        return this.color;
                    }
                }
            });

因为小生刚刚接触vue,所以,希望前辈能多加指点。


  • 2020-12-18 17:15:29

    coTurn stun服务器搭建,禁用turn

    https://github.com/coturn/coturn 在这里git clone 下来然后编译安装,一切默认即可。编译后,也可以不用安装。在编译目录下bin文件夹下有turnserver turnutils_stunclient turnutils_uclient 这三个等一下会用到的软件。

  • 2020-12-18 17:26:25

    coturn配置文件详细解释

    Coturn 是webrtc,p2p视频通话必不少的,主要包含2个主要功能stun服务, turn服务 Coturn 的githup地址为 https://github.com/coturn/coturn/

  • 2020-12-21 06:26:16

    为UIView添加点击事件

    最近经常碰到要将UIImageView和UILabel看成整体的情况,我于是就将他俩用UIView包起来,那么怎么给一个UIView添加点击事件,可以这么实现:

  • 2020-12-21 09:00:20

    Window.matchMedia() 方法详解

    matchMedia() 返回一个新的 MediaQueryList 对象,表示指定的媒体查询字符串解析后的结果。 matchMedia() 方法的值可以是任何一个 CSS @media 规则 的特性, 如 min-height, min-width, orientation 等。 MediaQueryList 对象有以下两个属性:

  • 2020-12-21 09:42:42

    iframe.contentWindow 操作iframe

    注:iframe.contentWindow这里,返回的是iframe的window对象,所以后面可以接着调用document方法,再接着调用getElementByTagName。那么就可以对iframe里面的元素进行操作了。

  • 2020-12-21 14:00:19

    iframe + postMessage跨域通信

    在实际项目开发中可能会碰到在 a.com 页面中嵌套 b.com 页面,这时第一反应是使用 iframe,但是产品又提出在 a.com 中操作,b.com 中进行显示,或者相反。

  • 2020-12-22 12:02:41

    ios开发优秀的开源框架,demo集合

    期待大家和我们一起共同维护,同时也期望大家随时能提出宝贵的意见(直接提交issues即可)。请广大网友只按照目录结构(即使目录结构有问题)添加三方库,并提交pull request。目录问题大家提出issues后楼主会及时更改的。