vue2.0自定义指令示例代码详解

作者:_Junjun 时间:2024-05-28 15:42:06 

1、什么是指令?

指令通常以"v-"作为前缀, 以方便Vue知道你在使用一种特殊的标记。

除了 Vue 核心携带着的一些默认指令(v-model 和 v-show)之外,

Vue 还允许你注册自己的自定义指令。某些情况下,还是需要对普通元素进行一些底层 DOM 访问,

这也是自定义指令仍然有其使用场景之处。

2、全局指令:

当页面加载时,元素将获取焦点,事实上,在访问页面时,如果你还没有点击任何地方,上面的输入框现在应该处于获取焦点的状态。现在让我们构建指令以完成此效果:


<template>
<div class="parent">
<input v-focus>
</div>
</template>
import Vue from 'vue'
import cnChildren from './children'
// 注册一个名为 `v-focus` 的全局自定义指令
Vue.directive('focus', {
 // 当绑定的元素插入到 DOM 时调用此函数……
 inserted: function (el) {
  // 元素调用 focus 获取焦点
  el.focus()
 }
});


如果你想要注册一个局部指令,也可以通过设置组件的 directives 选项:




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

我们有几个可用的钩子:

bind:在指令第一次绑定到元素时调用,只会调用一次。可以在此钩子函数中,执行一次性的初始化设置。
inserted:在已绑定的元素插入到父节点时调用(只能保证父节点存在,不一定存在于 document 中)。
update:在包含指令的组件的 VNode 更新后调用,但可能之前其子组件已更新。指令的值可能更新或者还没更新,然而可以通过比较绑定的当前值和旧值,来跳过不必要的更新(参考下面的钩子函数)。
componentUpdated:在包含指令的组件的 VNode 更新后调用,并且其子组件的 VNode 已更新。
unbind:在指令从元素上解除绑定时调用,只会调用一次。
每个钩子可以选择一些参数。

el:指令绑定的元素。可以用于直接操作 DOM。

binding:一个对象,包含以下属性:

1、name:指令的名称,不包括 v- 前缀。
  2、value:向指令传入的值。例如,在 v-my-directive="1 + 1" 中,传入的值是 2。
  3、oldValue:之前的值,只在 update 和 componentUpdated 钩子函数中可用。无论值是否发生变化,都可以使用。
  4、expression:指令绑定的表达式(expression),以字符串格式。例如,在 v-my-directive="1 + 1" 中,表达式是 "1 + 1"。
  5、arg:向指令传入的参数,如果有的话。例如,在 v-my-directive:foo 中,参数是 "foo"。
  6、modifiers:一个对象,包含修饰符,如果有的话。例如,在 v-my-directive.foo.bar 中,修饰符是 { foo: true, bar: true }。
vnode:由 Vue 编译器(Vue's compiler)生成的虚拟 Node 节点(virtual node)。更多细节请查看
VNode API。

除了 el 之外的其他参数,都应该是只读的,并且永远不要去修改它们。

3、自定义指令示例

如果指令需要多个值,你还可以向指令传入 JavaScript 对象字面量(object literal)。记住,指令能够接收所有有效的 JavaScript 表达式。


<div v-demo="{ color: 'white', text: 'hello!' }"></div>
Vue.directive('demo', function (el, binding) {
console.log(binding.value.color) // => "white"
console.log(binding.value.text) // => "hello!"
})

总结

以上所述是小编给大家介绍的vue2.0自定义指令示例代码详解,网站的支持!
如果你觉得本文对你有帮助,欢迎转载,烦请注明出处,谢谢!

来源:https://segmentfault.com/a/1190000018982637

标签:vue,自定义,指令
0
投稿

猜你喜欢

  • 使用Python webdriver图书馆抢座自动预约的正确方法

    2021-01-26 10:21:07
  • python模块之paramiko实例代码

    2022-08-08 08:34:51
  • Python深度学习之FastText实现文本分类详解

    2022-09-03 10:35:28
  • pytorch下大型数据集(大型图片)的导入方式

    2021-01-18 05:30:29
  • Python Django ORM与模型详解

    2022-01-03 10:40:53
  • Oracle如何批量将表中字段名全转换为大写(利用简单存储过程)

    2024-01-22 11:23:41
  • Django把SQLite数据库转换为Mysql数据库的过程

    2024-01-26 09:42:35
  • Android申请相机权限和读写权限实例

    2023-08-21 18:52:40
  • Python实现在线批量美颜功能过程解析

    2023-10-27 10:38:34
  • ASP 使用Filter函数来检索数组

    2011-04-30 16:49:00
  • Python 列表去重去除空字符的例子

    2021-07-11 02:49:14
  • 使用Python实现简单的服务器功能

    2021-06-29 09:25:31
  • python pandas query的使用方法

    2023-01-14 06:23:33
  • python系统指定文件的查找只输出目录下所有文件及文件夹

    2021-03-23 08:00:04
  • Python 使用input同时输入多个数的操作

    2023-09-23 22:36:42
  • Tensorflow中的降维函数tf.reduce_*使用总结

    2021-10-18 15:16:14
  • python实现日常记账本小程序

    2023-09-06 18:00:49
  • 微信小程序 picker-view 组件详解及简单实例

    2024-04-19 09:44:13
  • Django框架ORM数据库操作实例详解

    2024-01-24 00:23:33
  • python中获得当前目录和上级目录的实现方法

    2022-01-07 20:24:30
  • asp之家 网络编程 m.aspxhome.com