• vue directive具体的使用方法


    一、一个指令定义对象可以提供如下几个钩子函数 (均为可选):

    • bind:只调用一次,指令第一次绑定到元素时调用。在这里可以进行一次性的初始化设置。(注意:binding这个词绑定,顾名思义在这个bind中进行绑定函数)

    • inserted:被绑定元素插入父节点时调用 (仅保证父节点存在,但不一定已被插入文档中)。 (实际的效果的实现,dom操作等等,样式渲染)

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

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

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

    二、指令钩子函数会被传入以下参数:

    • el:指令所绑定的元素,可以用来直接操作 DOM 。
    • binding:一个对象,包含以下属性:vnode:Vue 编译生成的虚拟节点。移步 VNode API 来了解更多详情。
      • name:指令名,不包括 v- 前缀。
      • value:指令的绑定值,例如:v-my-directive="1 + 1" 中,绑定值为 2
      • oldValue:指令绑定的前一个值,仅在 update 和 componentUpdated 钩子中可用。无论值是否改变都可用。
      • expression:字符串形式的指令表达式。例如 v-my-directive="1 + 1" 中,表达式为 "1 + 1"
      • arg:传给指令的参数,可选。例如 v-my-directive:foo 中,参数为 "foo"
      • modifiers:一个包含修饰符的对象。例如:v-my-directive.foo.bar 中,修饰符对象为 { foo: true, bar: true }
    • oldVnode:上一个虚拟节点,仅在 update 和 componentUpdated 钩子中可用。

    三、具体事例

    1、clickoutside.js

    用途:clickoutside.js主要用于解决点解元素外的地方时执行函数  主要应用的常见有弹出层点击遮罩层是隐藏窗口,或者一些弹出层点击其他地方要消失的场景

    v-clickoutside具体是怎么实现的

    答:主要是通过在bind中定义函数 通过判断是否包含元素,执行binding.value函数

    export default {
      /*
       @param el 指令所绑定的元素
       @param binding {Object} 
       @param vnode vue编译生成的虚拟节点
       */
      bind (el, binding, vnode) {
        const documentHandler = function(e) {   
          if(!vnode.context || el.contains(e.target)) {
            return false;
          }
          if (binding.expression) {
            binding.value(e)
          }
        }
     
          document.addEventListener('click', documentHandler)
      },
      update (el, binding) {
      
      },
      unbind(el) {
        document.removeEventListener('click', documentHandler);
      }
    }

     

  • 相关阅读:
    __setattr__,__getattr__,__delattr__
    LeetCode 面试题42. 连续子数组的最大和
    LeetCode 53. 最大子序和
    LeetCode 面试题39. 数组中出现次数超过一半的数字
    LeetCode 169. 多数元素
    LeetCode 426.将二叉搜索树转化为排序的双向链表
    LeetCode 面试题36. 二叉搜索树与双向链表
    LeetCode 面试题35. 复杂链表的复制
    LeetCode 138. 复制带随机指针的链表
    LeetCode 面试题34. 二叉树中和为某一值的路径
  • 原文地址:https://www.cnblogs.com/heyinwangchuan/p/7905286.html
Copyright © 2020-2023  润新知