• 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);
      }
    }

     

  • 相关阅读:
    Web项目java.lang.OutOfMemoryError: PermGen space异常解决
    上传预览,图片展示大小的控制
    Eclipse常用插件安装_PropertiesEditor
    JDK的安装配置
    Eclipse与Tomcat的集成(无插件)
    Jsp&Servlet实现读取本地图片并展示
    DB2日期及时间的使用
    图片的另一种展现—将后台图片编码直接展现为图片
    Eclipse Task的使用
    Eclipse引入BASE64Encoder的问题
  • 原文地址:https://www.cnblogs.com/heyinwangchuan/p/7905286.html
Copyright © 2020-2023  润新知