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 Undefined,Null类型和NaN值区别
Oct 22 Javascript
google jQuery 引用文件,jQuery 引用地址集合(jquery 1.2.6至jquery1.5.2)
Apr 24 Javascript
用js小类库获取浏览器的高度和宽度信息
Jan 15 Javascript
javascript 另一种图片滚动切换效果思路
Apr 20 Javascript
基于JS2Image实现圣诞树代码
Dec 24 Javascript
js只执行1次的函数示例
Jul 20 Javascript
webpack多入口多出口的实现方法
Aug 17 Javascript
微信小程序发送短信验证码完整实例
Jan 07 Javascript
js实现ATM机存取款功能
Oct 27 Javascript
小程序:授权、登录、session_key、unionId的详解
May 15 Javascript
js中Map和Set的用法及区别实例详解
Feb 15 Javascript
React如何使用axios请求数据并把数据渲染到组件
Aug 05 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
法压式咖啡之制作法
2021/03/03 冲泡冲煮
PHP中路径问题的解决方案
2006/10/09 PHP
PHP生成图片验证码、点击切换实例
2014/06/25 PHP
PHP开发框架Laravel数据库操作方法总结
2014/09/03 PHP
php实现的用户查询类实例
2015/06/18 PHP
thinkphp autoload 命名空间自定义 namespace
2015/07/17 PHP
PHP中Enum(枚举)用法实例详解
2015/12/07 PHP
Yii2隐藏frontend/web和backend/web的方法
2015/12/12 PHP
基于php双引号中访问数组元素报错的解决方法
2018/02/01 PHP
thinkPHP5.1框架中Request类四种调用方式示例
2019/08/03 PHP
深入认识javascript中的eval函数
2009/11/02 Javascript
Extjs407 getValue()和getRawValue()区别介绍
2013/05/21 Javascript
javascript复制粘贴与clipboardData的使用
2014/10/16 Javascript
jQuery实现按钮的点击 全选/反选 单选框/复选框 文本框 表单验证
2015/06/25 Javascript
基于JavaScript实现文字超出部分隐藏
2016/02/29 Javascript
使用JS读取XML文件的方法
2016/11/25 Javascript
vue mixins组件复用的几种方式(小结)
2017/09/06 Javascript
webpack实现一个行内样式px转vw的loader示例
2018/09/13 Javascript
微信小程序实现Swiper轮播图效果
2019/11/22 Javascript
Vue快速实现通用表单验证的示例代码
2020/01/09 Javascript
使用vue编写h5公众号跳转小程序的实现代码
2020/11/27 Vue.js
[03:09]DOTA2亚洲邀请赛 LGD战队出场宣传片
2015/02/07 DOTA
对于Python的Django框架部署的一些建议
2015/04/09 Python
在Mac OS上部署Nginx和FastCGI以及Flask框架的教程
2015/05/02 Python
微信跳一跳python辅助脚本(总结)
2018/01/11 Python
python查询mysql,返回json的实例
2018/03/26 Python
详解python数据结构和算法
2019/04/18 Python
简单了解python 邮件模块的使用方法
2019/07/24 Python
python随机生成大小写字母数字混合密码(仅20行代码)
2020/02/01 Python
Python Selenium XPath根据文本内容查找元素的方法
2020/12/07 Python
菲律宾酒店预订网站:Hotels.com菲律宾
2017/07/12 全球购物
美国大码时尚女装购物网站:ELOQUII
2017/12/28 全球购物
简历中个人自我评价范文
2013/12/26 职场文书
投标承诺书怎么写
2014/05/24 职场文书
美术教师个人总结
2015/02/06 职场文书
2016七夕情人节广告语
2016/01/28 职场文书