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 相关文章推荐
用ADODB.Stream转换
Jan 22 Javascript
javascript实现动态增加删除表格行(兼容IE/FF)
Apr 02 Javascript
JavaScript实现的使用键盘控制人物走动实例
Aug 27 Javascript
JavaScript 事件入门知识
Apr 13 Javascript
JS原型对象的创建方法详解
Jun 16 Javascript
JS使用JSON作为参数实例分析
Jun 23 Javascript
Vue结合原生js实现自定义组件自动生成示例
Jan 21 Javascript
解决ajax不能访问本地文件问题(利用js跨域原理)
Jan 24 Javascript
JavaScript Drum Kit 指南(纯 JS 模拟敲鼓效果)
Jul 23 Javascript
jquery实现点击a链接,跳转之后,该a链接处显示背景色的方法
Jan 18 jQuery
使用iView Upload 组件实现手动上传图片的示例代码
Oct 01 Javascript
详解vue 项目白屏解决方案
Oct 31 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下实现一个阿拉伯数字转中文数字的函数
2008/07/10 PHP
PHP防止注入攻击实例分析
2014/11/03 PHP
PHP程序员必须清楚的问题汇总
2014/12/18 PHP
php实现中文字符截取防乱码方法汇总
2015/04/29 PHP
关于laravel后台模板laravel-admin select框的使用详解
2019/10/03 PHP
jquery代码实现多选、不同分享功能
2015/07/31 Javascript
谈谈我对JavaScript原型和闭包系列理解(随手笔记8)
2015/12/24 Javascript
jQuery插件实现表格隔行变色及鼠标滑过高亮显示效果代码
2016/02/25 Javascript
概述如何实现一个简单的浏览器端js模块加载器
2016/12/07 Javascript
jQuery Chosen通用初始化
2017/03/07 Javascript
Vue中使用vux的配置详解
2017/05/05 Javascript
Mac系统下Webstorm快捷键整理大全
2017/05/28 Javascript
浅谈express 中间件机制及实现原理
2017/08/31 Javascript
JavaScript实现一个带AI的井字棋游戏源码
2018/05/21 Javascript
vue实现点击选中,其他的不选中方法
2018/09/05 Javascript
微信小程序之下拉列表实现方法解析(附完整源码)
2019/08/23 Javascript
vue中watch和computed的区别与使用方法
2020/08/23 Javascript
python实现分析apache和nginx日志文件并输出访客ip列表的方法
2015/04/04 Python
python验证码识别的示例代码
2017/09/21 Python
python绘制地震散点图
2019/06/18 Python
Django 多表关联 存储 使用方法详解 ManyToManyField save
2019/08/09 Python
Python定时任务随机时间执行的实现方法
2019/08/14 Python
Python Django 简单分页的实现代码解析
2019/08/21 Python
浅谈keras的深度模型训练过程及结果记录方式
2020/01/24 Python
Tensorflow中的降维函数tf.reduce_*使用总结
2020/04/20 Python
Ivory Isle Designs美国/加拿大:婚礼和活动文具公司
2018/08/21 全球购物
LUISAVIAROMA中国官网:时尚奢侈品牌购物网站
2020/11/01 全球购物
J2EE系统只能是基于web
2015/09/08 面试题
乔迁宴答谢词
2014/01/21 职场文书
煤矿安全演讲稿
2014/05/09 职场文书
银行保安拾金不昧表扬稿
2015/05/05 职场文书
化验室安全管理制度
2015/08/06 职场文书
祝酒词范文
2015/08/12 职场文书
2016年中学法制宣传日活动总结
2016/04/01 职场文书
Python实现视频自动打码的示例代码
2022/04/08 Python
详解NumPy中的线性关系与数据修剪压缩
2022/05/25 Python