Vue 浅谈自定义指令 directive

    技术2022-07-11  95

    自定义指令

     

    用途:需要对普通 DOM 元素进行底层操作

    除了核心功能默认内置的指令 ( 和 ),Vue 也允许注册自定义指令。注意,在 Vue2.0 中,代码复用和抽象的主要形式是组件。然而,有的情况下,你仍然需要对普通 DOM 元素进行底层操作,这时候就会用到自定义指令。

     

    🌰 例子:输入框获取焦点

     

    1. 定义 v-focus 指令

    (1) 全局自定义指令

    // main.js // 注册一个全局自定义指令 `v-focus` Vue.directive('focus', { // 当被绑定的元素插入到 DOM 中时…… inserted: function (el) { // 聚焦元素 el.focus() } })

     (2)局部自定义指令

    如果想注册局部指令,组件中也接受一个 directives 的选项:

    directives: { focus: { // 指令的定义 inserted: function (el) { el.focus() } } }

    2. 使用 v-focus 指令

    然后你可以在模板中任何元素上使用新的 v-focus property,如下:

    <input type="text" v-focus >

     

     

    钩子函数

    bind:只调用一次,指令第一次绑定到元素时调用。在这里可以进行一次性的初始化设置。

    inserted:被绑定元素插入父节点时调用 (仅保证父节点存在,但不一定已被插入文档中)。

    update:所在组件的 VNode 更新时调用,但是可能发生在其子 VNode 更新之前。指令的值可能发生了改变,也可能没有。但是你可以通过比较更新前后的值来忽略不必要的模板更新 (详细的钩子函数参数见下)。

    componentUpdated:指令所在组件的 VNode 及其子 VNode 全部更新后调用。

    unbind:只调用一次,指令与元素解绑时调用。

    Vue.directive('mydirective', { bind() {}, inserted() {}, update() {}, componentUpdated() {}, unbind() {} });
    Processed: 0.012, SQL: 9