vue

Vue.js自定义指令

2019-07-31  本文已影响14人  缺月楼

自定义指令的基本用法

和组件类似分全局注册和局部注册,区别就是把component换成了derective.

钩子函数

指令定义函数提供了几个钩子函数(可选):

钩子函数的参数有:

binding: 一个对象,包含以下属性:

  • name: 指令名,不包括 前缀。
  • value: 指令的绑定值, 例如: v­my­directive=”1 + 1”, value的值是 2。
  • oldValue: 指令绑定的前一个值,仅在 updatecomponentUpdated 钩子中可用。无论值是否改变都可用。
  • expression: 绑定值的字符串形式。 例如 v­my­directive=”1 + 1”expression值是“1 + 1”。
  • arg: 传给指令的参数。例如 v­my­directive:fooarg的值是 “foo”。
  • modifiers: 一个包含修饰符的对象。 例如: v­my­directive.foo.bar, 修饰符对
    象,,,modifiers的值是 { foo: true, bar: true }
 <div id="app">
        获取焦点:
        <input type="text" v-focus>
    </div>
    <script src="https://cdn.jsdelivr.net/npm/vue@2.5.16/dist/vue.js"></script>

    <script>
        // 自定义指令:
        Vue.directive('focus', {
            // 指令的选项   插入父节点的时候就调用
            inserted: function(el) {
                el.focus();
            }
        });
        var app = new Vue({
            el: '#app',
            data: {}

        })
    </script>
上一篇 下一篇

猜你喜欢

热点阅读