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 相关文章推荐
JavaScript 对话框和状态栏使用说明
Oct 25 Javascript
js模仿html5 placeholder适应于不支持的浏览器
Jan 13 Javascript
自定义的一个简单时尚js下拉选择框
Nov 20 Javascript
jquery实现人性化的有选择性禁用鼠标右键
Jun 30 Javascript
详解javascript函数的参数
Nov 10 Javascript
jQuery Easyui实现左右布局
Jan 26 Javascript
gulp-uglify 与gulp.watch()配合使用时报错(重复压缩问题)
Aug 24 Javascript
jQuery焦点图左右转换效果
Dec 12 Javascript
vue2.X组件学习心得(新手必看篇)
Jul 05 Javascript
详解React 16 中的异常处理
Jul 28 Javascript
JS构造一个html文本内容成文件流形式发送到后台
Jul 31 Javascript
javascript中的数据类型检测方法详解
Aug 07 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学习笔记(二) 了解PHP的基本语法以及目录结构
2014/08/04 PHP
PHP性能分析工具XHProf安装使用教程
2015/05/13 PHP
基于PHPexecl类生成复杂的报表表头示例
2016/10/14 PHP
Laravel5.5 动态切换多语言的操作方式
2019/10/25 PHP
JavaScript 封装Ajax传递的数据代码
2009/06/05 Javascript
JavaScript函数中关于valueOf和toString的理解
2016/06/14 Javascript
JS实现可编辑的后台管理菜单功能【附demo源码下载】
2016/09/13 Javascript
Angularjs根据json文件动态生成路由状态的实现方法
2017/04/17 Javascript
Node.js安装配置图文教程
2017/05/10 Javascript
详谈js对url进行编码和解码(三种方式的区别)
2017/08/16 Javascript
JSON在Javascript中的使用(eval和JSON.parse的区别)详细解析
2017/09/05 Javascript
layui 监听表格复选框选中值的方法
2018/08/15 Javascript
laydate如何根据开始时间或者结束时间限制范围
2018/11/15 Javascript
angular6开发steps步骤条组件
2019/07/04 Javascript
关于ligerui子页面关闭后,父页面刷新,重新加载的方法
2019/09/27 Javascript
JavaScript使用百度ECharts插件绘制饼图操作示例
2019/11/26 Javascript
Vue中正确使用Element-UI组件的方法实例
2020/10/13 Javascript
[01:02:55]CHAOS vs Mineski 2019国际邀请赛小组赛 BO2 第二场 8.16
2019/08/18 DOTA
讲解Python中for循环下的索引变量的作用域
2015/04/15 Python
对于Python装饰器使用的一些建议
2015/06/03 Python
Python实现连接MySql数据库及增删改查操作详解
2019/04/16 Python
Python3的unicode编码转换成中文的问题及解决方案
2019/12/10 Python
40行Python代码实现天气预报和每日鸡汤推送功能
2020/02/27 Python
pycharm远程连接vagrant虚拟机中mariadb数据库
2020/06/05 Python
CSS3——齿轮转动关键代码
2013/05/02 HTML / CSS
HTML5 Canvas中绘制椭圆的4种方法
2015/04/24 HTML / CSS
巧克力领导品牌瑞士莲美国官网:Lindt Chocolate美国
2016/08/25 全球购物
中药专业大学生医药工作求职信
2013/10/25 职场文书
商业活动邀请函
2014/02/04 职场文书
学校四风问题对照检查材料思想汇报
2014/09/26 职场文书
四风查摆剖析材料
2014/10/10 职场文书
股东授权委托书
2014/10/15 职场文书
2014大学辅导员工作总结
2014/12/02 职场文书
大明湖导游词
2015/02/03 职场文书
mysql优化之query_cache_limit参数说明
2021/07/01 MySQL
nginx的zabbix 5.0安装部署的方法步骤
2021/07/16 Servers