vue除了有v-if等内置指令,我们也可以创建自定义指令。

  例:我们可以实现一个可以每隔一秒闪烁的节点,类似于<blink>标签的行为。添加一个指令类似于添加一个过滤器,可以将他传入vue实例或组件的directives属性,或者使用vue.directive()注册一个全局指令。传入指令的名字以及包含钩子函数的对象,这些钩子函数会在设置了该指令的元素的生命周期的各个阶段运行。

<div v-blink>闪烁的盒子</div>
  Vue.directive('blink',{
        bind(el){
          let isVisible = true
          setInterval(()=>{
            isVisible = !isVisible;
            el.style.visibility = isVisible ? 'visible' : 'hidden';
          },1000)
        }
      })

  

  5个钩子函数

    bind:会在指令绑定到元素时被调用。

    inserted:在被绑定的元素被添加到父节点时被调用。和mounted一样,并不能保证元素被添加DOM上。可以使用this.$nextTick保证

    update: 节点被更新时调用,但是该组件的子组件可能还没有更新

    componentUpdated: 更新完成后调用

    unbind: 用于指令拆除,指令被解绑调用。

    以上钩子函数不必每次都调用所有钩子,他们是可选的。bind和update钩子常用,如果想同时调用,可以传入一个函数作为参数,这个函数会分别被这两个

Vue.directive('test',(el)=>{
//代码会被 bind update 两个钩子调用
})

  钩子函数参数

    在前面已经回顾了指令可以接收参数,修饰符和值。可以传入钩子函数的第二个参数---binding---来访问这些所有内容,binding对象会包含以下属性

    例:v-my:example.one.two="test"

    name: 属性指令的名称,不包含v-。所以name的值为my

    value: 传入指令的值。在这个例子中它将是test表达式的计算值。{test:hello world},那么value值就是hello word

    oldValue: 属性上次传入得值,它只有子在update和componentUpdated中使用,如果改变test得值update被调用,此时得value得值是新的

    expression: 指令表达式的字符串形式,之后会对该表达式求值。在这个例子中它的值为test

    arg:传入指令的参数  也就是example

    modifiers: 属性是一个包含所有传入指令的修饰符对象  也就是 one tow。

Vue.directive('blink',{
bind(el,binding){
let isVisible = true
setInterval(()=>{
isVisible = !isVisible;
el.style.visibility = isVisible ? 'visible' : 'hidden';
},binding.value || )
}
})

    上面的代码中添加了binding参数,并设置了计时时间。但是例子缺少了用于处理该指令值变化后更新组件的逻辑。要实现这一点需要将setInterval返回的ID存到元素的data属性上,然后再update钩子函数中清除旧定时器,之后再创建一个新的定时器。

自定义指令 VUE基础回顾7的更多相关文章

  1. vue中自定义指令vue.direvtive,自定义过滤器vue.filter(),vue过渡transition

    自定义指令 默认设置的核心指令( v-model,v-bind,v-for,v-if,v-on等 ),Vue 也允许注册自定义指令.注意,在 Vue2.0 里面,代码复用的主要形式和抽象是组件——然而 ...

  2. 自定义指令directive基础用法

    官方链接:http://doc.vue-js.com/v2/guide/custom-directive.html#simplest-directive-example 在main.js中注册自定义指 ...

  3. 一、VUE基础回顾1

    1.v-if和v-show v-if 和v-show都可以显示和隐藏元素: 区别:(1)v-if初始值为false那么这个元素不会被渲染 ,v-show不管初始值为何值都会被渲染 (2)v-if是控制 ...

  4. VUE基础回顾2

    1.响应式 vue修改了每个添加到data上的对象,当该对象发生变化时vue会收到通知,从而实现响应式.对象的每个属性都会被替换为getter,setter方法. 有两种方式实现data对象的监听 ( ...

  5. VUE基础回顾6

    1.ref ref可以直接访问元素,而不需要使用querySelector或者其他dom节点的原生方法. <div ref = "box"></div> 在 ...

  6. 动画 VUE基础回顾8

    过渡和动画 使用<transition> 组件包裹 例: <transition name="fade"> <div v-if="true& ...

  7. vue基础回顾 router

    vue-router 1. 底层原理 hash 或者h5 histroy(有兼容性) 2. 使用的时候Vue需要引入VueRouter Vue.use(VueRouter) //VueRouter 底 ...

  8. vue 基础-->进阶 教程(2): 指令、自定义指令、组件

    第二章 建议学习时间4小时  课程共3章 前面的nodejs教程并没有停止更新,因为node项目需要用vue来实现界面部分,所以先插入一个vue教程,以免不会的同学不能很好的完成项目. 本教程,将从零 ...

  9. Vue基础进阶 之 自定义指令

    自定义指令-----钩子函数 自定义指令 除了内置指令,Vue也允许用户自定义指令: 注册指令:通过全局API Vue.directive可以注册自定义指令: 自定义指令的钩子函数: bind: in ...

随机推荐

  1. MyBatis(十一):Mybatis 动态SQL语句完成多条件查询

    之前文章中对in的用法做过讲解:<MyBatis(四):mybatis中使用in查询时的注意事项> 实际上对于多个参数的用法也是这是注意的: 多参&if判空&List集合判 ...

  2. Eclipse中SpringBoot项目POM文件报UnKnown的解决方案

    在项目中使用spring-boot-starter-parent的2.1.5.RELEASE版本时发现会出现POM错误(Unknown),其实这错误可以无视,但如果你实在看不下去可以在POM中添加如下 ...

  3. odoo开发笔记 -- 提高访问安全性的一种方式

    场景描述: 最近在做项目的过程中,需要需要将odoo应用集成到其他系统中, 在对方的系统中点击我们的应用,打开对应系统,但是界面不做跳转,在当前页面打开,并且浏览器地址栏只显示IP+应用名,不让显示o ...

  4. StandardServer.await: Invalid command '' received

    tomcat服务运行时 后台提输出警告:StandardServer.await: Invalid command '' received 这个警告是 多个tomcat启动时会出现端口占用的情况, 将 ...

  5. qt 获取汉字拼音首字母

    #include "mainwindow.h"#include "ui_mainwindow.h"#include <QDebug>#include ...

  6. jquery与angular的交互

    HTML: <table class="table table-striped" ng-app="myApp"> <tr> <th ...

  7. 【bat】九九表

    @echo off & setlocal EnableDelayedExpansion title 九九表 for /l %%a in (1,1,9) do ( set temp= for / ...

  8. mybatis一级二级缓存

    一级缓存分析 不需要任何配置 ,mybatis本身带有 一级缓存是SqlSession范围的缓存,当调用SqlSession的修改,添加,删除,commit(),close()等方法时,就会清空一级缓 ...

  9. 迪杰斯特拉算法(Dijkstra) (基础dij+堆优化) BY:优少

    首先来一段百度百科压压惊... 迪杰斯特拉算法(Dijkstra)是由荷兰计算机科学家狄克斯特拉于1959 年提出的,因此又叫狄克斯特拉算法.是从一个顶点到其余各顶点的最短路径算法,解决的是有权图中最 ...

  10. C++中const限定符

    const基础 C++中的const,用于定义一个常量,这个常量的值不能被修改.因为const对象一旦创建就不能修改,所以const对象必须初始化.const常量特征仅仅在执行改变其本身的操作时才会发 ...