Vue自定义指令

文章介绍了在Vue2.0中,当组件无法满足需求时如何使用自定义指令进行DOM操作。自定义指令提供了如`v-focus`等的钩子函数,用于初始化、更新和解绑等阶段的操作,并给出了初级和高级应用示例,如鼠标聚焦、图片懒加载等。
摘要由CSDN通过智能技术生成

在 Vue2.0 中,代码复用和抽象的主要形式是组件。然而,有的情况下,你仍然需要实现对普通 DOM 元素进行底层操作,并且vue中没有你所需要的指令时,这时候就会用到自定义指令。

一般需要对DOM元素进行底层操作时使用,尽量只用来操作 DOM展示,不修改内部的值。当使用自定义指令直接修改 value 值时绑定v-model的值也不会同步更新;如必须修改可以在自定义指令中使用keydown事件,在vue组件中使用 change事件,回调中修改vue数据;

vue自定义指令蜂窝全局和局部的自定义指令

1)自定义指令基本内容

  • 全局定义:Vue.directive("focus",{})

  • 局部定义:directives:{focus:{}}

  • 钩子函数:指令定义对象提供钩子函数

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

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

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

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

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

  • 钩子函数参数

o el:绑定元素

o bing: 指令核心对象,描述指令全部信息属性

o name

o value

o oldValue

o expression

o arg

o modifers

o vnode 虚拟节点

o oldVnode:上一个虚拟节点(更新钩子函数中才有用)

(2)使用场景

  • 普通DOM元素进行底层操作的时候,可以使用自定义指令

  • 自定义指令是用来操作DOM的。尽管Vue推崇数据驱动视图的理念,但并非所有情况都适合数据驱动。自定义指令就是一种有效的补充和扩展,不仅可用于定义任何的DOM操作,并且是可复用的。

(3)使用案例

初级应用:

  • 鼠标聚焦

  • 下拉菜单

  • 相对时间转换

  • 滚动动画

高级应用:

  • 自定义指令实现图片懒加载

  • 自定义指令集成第三方插件

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值