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 相关文章推荐
JSQL  一个 web DB 的封装
May 05 Javascript
JS判断元素为数字的奇异写法分享
Aug 01 Javascript
JS正则表达式验证数字代码
Jan 28 Javascript
javascript数组输出的两种方式
Jan 13 Javascript
javascript父子页面通讯实例详解
Jul 17 Javascript
原生js更改css样式的两种方式
Mar 15 Javascript
微信小程序实现多宫格抽奖活动
Apr 15 Javascript
vue中简单弹框dialog的实现方法
Feb 26 Javascript
如何让微信小程序页面之间的通信不再变困难
Jun 03 Javascript
layui异步加载table表中某一列数据的例子
Sep 16 Javascript
vue-cli3.0实现一个多页面应用的历奇经历记录总结
Mar 16 Javascript
javascript实现前端input密码输入强度验证
Jun 24 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 socket(fsockopen)的应用实例分析
2013/06/02 PHP
php一次性删除前台checkbox多选内容的方法
2013/09/22 PHP
PHP static局部静态变量和全局静态变量总结
2014/03/02 PHP
PHP根据两点间的经纬度计算距离
2014/10/31 PHP
thinkPHP+mysql+ajax实现的仿百度一下即时搜索效果详解
2019/07/15 PHP
PHP实现获取文件mime类型多种方法解析
2020/05/28 PHP
PHP延迟静态绑定使用方法实例解析
2020/09/05 PHP
基于jquery扩展漂亮的CheckBox(自己编写)
2013/11/19 Javascript
ext combobox动态加载数据库数据(附前后台)
2014/06/17 Javascript
Jquery树插件zTree用法入门教程
2015/02/17 Javascript
JavaScript实现多种排序算法
2016/02/24 Javascript
angular2使用简单介绍
2016/03/01 Javascript
jQuery表单验证简单示例
2016/10/17 Javascript
jQuery下拉菜单的实现代码
2016/11/03 Javascript
Angularjs的Controller间通信机制实例分析
2016/11/07 Javascript
JQuery查找子元素find()和遍历集合each的方法总结
2017/03/07 Javascript
微信小程序 合法域名校验出错详解及解决办法
2017/03/09 Javascript
在Vue中使用echarts的实例代码(3种图)
2017/07/10 Javascript
基于JavaScript实现选项卡效果
2017/07/21 Javascript
JS简单获取并修改input文本框内容的方法示例
2018/04/08 Javascript
Node.js Express安装与使用教程
2018/05/11 Javascript
Angular脚手架开发的实现步骤
2019/04/09 Javascript
element-ui table行点击获取行索引(index)并利用索引更换行顺序
2020/02/27 Javascript
vue表单验证之禁止input输入框输入空格
2020/12/03 Vue.js
[02:20]2014DOTA2西雅图邀请赛 MVP外卡赛首胜采访
2014/07/09 DOTA
Python多线程编程(五):死锁的形成
2015/04/05 Python
简单介绍Ruby中的CGI编程
2015/04/10 Python
python在OpenCV里实现投影变换效果
2019/08/30 Python
分享8点超级有用的Python编程建议(推荐)
2019/10/13 Python
python实现高斯投影正反算方式
2020/01/17 Python
通过python 执行 nohup 不生效的解决
2020/04/16 Python
瑞典时尚服装购物网站:Miinto.se
2017/10/30 全球购物
教师批评与自我批评材料
2014/10/16 职场文书
药品开票员岗位职责
2015/04/15 职场文书
何玥事迹观后感
2015/06/16 职场文书
Echarts如何重新渲染实例详解
2022/05/30 Javascript