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


Posted in Javascript onApril 25, 2019

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自定义指令示例代码详解,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对三水点靠木网站的支持!
如果你觉得本文对你有帮助,欢迎转载,烦请注明出处,谢谢!

Javascript 相关文章推荐
在修改准备发的批量美化select+可修改select时,在非IE下发现了几个问题
Jan 09 Javascript
js格式化金额可选是否带千分位以及保留精度
Jan 28 Javascript
JS实现页面超时后自动跳转到登陆页面
Jan 19 Javascript
javascript原型模式用法实例详解
Jun 04 Javascript
jQuery使用ajax方法解析返回的json数据功能示例
Jan 10 Javascript
jQuery元素选择器实例代码
Feb 06 Javascript
JS实现简单的天数计算器完整实例
Apr 28 Javascript
Bootstrap 表单验证formValidation 实现远程验证功能
May 17 Javascript
关于Google发布的JavaScript代码规范你要知道哪些
Apr 04 Javascript
vue2单元测试环境搭建
May 24 Javascript
微信小程序框架wepy之动态控制类名
Sep 14 Javascript
JavaScript数组 几个常用方法总结
Nov 11 Javascript
Vue开发之封装分页组件与使用示例
Apr 25 #Javascript
Vue注册组件命名时不能用大写的原因浅析
Apr 25 #Javascript
从零到一详聊创建Vue工程及遇到的常见问题
Apr 25 #Javascript
详解vue项目中调用百度地图API使用方法
Apr 25 #Javascript
Vue开发之watch监听数组、对象、变量操作分析
Apr 25 #Javascript
详解JS实现简单的时分秒倒计时代码
Apr 25 #Javascript
node.js ws模块搭建websocket服务端的方法示例
Apr 25 #Javascript
You might like
php实现图片添加描边字和马赛克的方法
2014/12/10 PHP
PHP call_user_func和call_user_func_array函数的简单理解与应用分析
2019/11/25 PHP
给Function做的OOP扩展
2009/05/07 Javascript
javascript 构建一个xmlhttp对象池合理创建和使用xmlhttp对象
2010/01/15 Javascript
ExtJS4 表格的嵌套 rowExpander应用
2014/05/02 Javascript
JS控制静态页面之间传递参数获取参数并应用的简单实例
2016/08/10 Javascript
jQuery禁用快捷键例如禁用F5刷新 禁用右键菜单等的简单实现
2016/08/31 Javascript
BooStrap对导航条的改造实践小结
2016/09/21 Javascript
AngularJS实现与Java Web服务器交互操作示例【附demo源码下载】
2016/11/02 Javascript
AngularJs每天学习之总体介绍
2017/08/07 Javascript
JS基于对象的特性实现去除数组中重复项功能详解
2017/11/17 Javascript
vue 中动态绑定class 和 style的方法代码详解
2018/06/01 Javascript
基于bootstrap页面渲染的问题解决方法
2018/08/09 Javascript
mpvue项目中使用第三方UI组件库的方法
2018/09/30 Javascript
深入浅析vue-cli@3.0 使用及配置说明
2019/05/08 Javascript
解决vue刷新页面以后丢失store的数据问题
2020/08/11 Javascript
Vue+Element自定义纵向表格表头教程
2020/10/26 Javascript
python搭建虚拟环境的步骤详解
2016/09/27 Python
Tornado协程在python2.7如何返回值(实现方法)
2017/06/22 Python
TensorFlow tf.nn.softmax_cross_entropy_with_logits的用法
2020/04/19 Python
Python实现敏感词过滤的4种方法
2020/09/12 Python
data:image data url 文件转为Blob上传后端的方法
2019/07/16 HTML / CSS
美国值得信赖的婚恋交友网站:eHarmony
2018/10/04 全球购物
ALDO美国官网:加拿大女鞋品牌
2018/12/28 全球购物
寻找完美的房车租赁:RVShare
2019/02/23 全球购物
哈萨克斯坦最大的时装、鞋子和配饰在线商店:Lamoda.kz
2019/11/19 全球购物
毕业自我鉴定
2013/11/05 职场文书
办公室文员工作自我评价
2013/12/01 职场文书
小学安全工作汇报材料
2014/08/19 职场文书
车辆委托书范本
2014/10/05 职场文书
2015年双拥工作总结
2015/04/08 职场文书
老员工辞职信范文
2015/05/12 职场文书
2016年第32个教师节致辞
2015/11/26 职场文书
《槐乡的孩子》教学反思
2016/02/20 职场文书
Mybatis是这样防止sql注入的
2021/12/06 Java/Android
Redis高可用集群redis-cluster详解
2022/03/20 Redis