vue.js内部自定义指令与全局自定义指令的实现详解(利用directive)


Posted in Javascript onJuly 11, 2017

前言

大家都知道在Vue中,我们平时数据驱动视图时候,内部自带的指令有时候解决不了一些需求,这时候,Vue给我们一个很好用的东东来实现自定义指令,这就是directive。下面话不多说了,来一起看看详细的介绍:

directive

这个单词是我们写自定义指令的关键字哦

自定义指令为我们提供了几个钩子函数,这时候你一定好奇什么是钩子函数,说简单点,就是集中表现状态

  • bind: 只调用一次,指令第一次绑定到元素时调用,用这个钩子函数可以定义一个在绑定时执行一次的初始化动作。
  • inserted: 被绑定元素插入父节点时调用(父节点存在即可调用,不必存在于 document 中)。
  • update: 被绑定元素所在的模板更新时调用,而不论绑定值是否变化。通过比较更新前后的绑定值,可以忽略不必要的模板更新(详细的钩子函数参数见下)。
  • componentUpdated: 被绑定元素所在模板完成一次更新周期时调用。
  • unbind: 只调用一次, 指令与元素解绑时调用。

下面我们开始上代码,让我们更好的理解自定义指令怎么做

<!DOCTYPE html>
<html lang="en">
<head>
 <meta charset="UTF-8">
 <title>Document</title>
 <script src="https://unpkg.com/vue/dist/vue.js"></script>
</head>
<body>
 <div id="app">
 
 <div class="ab" v-css="{'color':'red','font-size':'30px'}">
 hello
 </div>
 <input type="text" v-focus>
 </div>
 
</body>
</html>

在html中,我们看到了两个指令v-cssv-focus

我们自定义指令时候,一定前面要带上v-

Vue.directive("css",{
 //钩子函数 ,el就是当前元素
 inserted(el,binding){
 //el绑定的元素本身
 //binding就是css指令里面的的对象元素
 let styleobj=binding.value,arr=[];
 for(let key in styleobj){
  arr.push(key+":"+styleobj[key])
  }
 arr=arr.join(";");
 el.style.cssText=arr;
 },
 bind(el,binding) {
 //指令绑定在元素上时候执行,只执行一次
 }
});
 new Vue({
 el:'#app',
 data:{
  show:true
 },
 directives:{
 focus:{
  inserted(el,binding){
  //el绑定的元素本身
  //binding就是css指令里面的的对象元素
  el.focus();
  }
  }
 }
 });

在js里面我们可以看到

Vue.directive("css",{})

我们在 new Vue外部定义了这样一段代码,这就是我们全局自定义指令的模板方式

  • css是自定义指令的名字
  • {}里面我们写上钩子函数就可以

我们所有的钩子函数里面,基本都会有2个参数el,binding

  • el: 指令所绑定的元素,可以用来直接操作 DOM 。
  • binding 绑定元素本身的一个对象
  • vue.js内部自定义指令与全局自定义指令的实现详解(利用directive)

从上面我们可以看到,binding里面保留绑定指令的name和value,这些很重要

局部自定义指令

directives:{
 name:{

 }
 }

区别在于,我们写在new Vue里面,里面api操作和上面的全局自定义指令一样

下面我们开始看代码运行结果

vue.js内部自定义指令与全局自定义指令的实现详解(利用directive)

我们可以看到样式引用上去了

文本框也获取了焦点

总结

以上就是这篇文章的全部内容了,希望本文的内容对大家的学习或者工作能带来一定的帮助,如果有疑问大家可以留言交流,谢谢大家对三水点靠木的支持。

Javascript 相关文章推荐
JavaScript判断一个URL链接是否有效的实现方法
Oct 08 Javascript
javascript学习笔记(一) 在html中使用javascript
Jun 18 Javascript
js判断输入是否为数字的具体实例
Aug 03 Javascript
浅谈Javascript如何实现匀速运动
Dec 19 Javascript
JavaScript语言对Unicode字符集的支持详解
Dec 30 Javascript
window.setInterval()方法的定义和用法及offsetLeft与style.left的区别
Nov 11 Javascript
如何判断Javascript对象是否存在的简单实例
May 18 Javascript
JavaScript中的call和apply的用途以及区别
Jan 11 Javascript
JavaScript+Html5实现按钮复制文字到剪切板功能(手机网页兼容)
Mar 30 Javascript
微信小程序开发之IOS和Android兼容的问题
Sep 26 Javascript
vue 项目打包通过命令修改 vue-router 模式 修改 API 接口前缀
Jun 13 Javascript
vue-cli在 history模式下的配置详解
Nov 26 Javascript
javascript 玩转Date对象(实例讲解)
Jul 11 #Javascript
使用jQuery实现动态添加小广告
Jul 11 #jQuery
Vue中父组件向子组件通信的方法
Jul 11 #Javascript
实例讲解DataTables固定表格宽度(设置横向滚动条)
Jul 11 #Javascript
网页中的图片查看器viewjs使用方法
Jul 11 #Javascript
自定义事件解决重复请求BUG的问题
Jul 11 #Javascript
关于js中的鼠标事件总结
Jul 11 #Javascript
You might like
php上传、管理照片示例
2006/10/09 PHP
深入理解PHP中的Session和Cookie
2013/06/21 PHP
PHP内核探索:哈希表碰撞攻击原理
2015/07/31 PHP
PHP实现多关键字加亮功能
2016/10/21 PHP
php运行报错Call to undefined function curl_init()的最新解决方法
2016/11/20 PHP
小议Function.apply()之二------利用Apply的参数数组化来提高 JavaScript程序性能
2006/11/30 Javascript
通用javascript脚本函数库 方便开发
2009/10/13 Javascript
10个基于Jquery的幻灯片插件教程
2010/10/29 Javascript
getElementByIdx_x js自定义getElementById函数
2012/01/24 Javascript
JS日期和时间选择控件升级版(自写)
2013/08/02 Javascript
用js判断是否为360浏览器的实现代码
2015/01/15 Javascript
浅谈javascript中的instanceof和typeof
2015/02/27 Javascript
很棒的js选项卡切换效果
2016/07/15 Javascript
JavaScript获取中英文混合字符串长度的方法示例
2017/02/04 Javascript
基于Bootstrap实现城市三级联动
2017/11/23 Javascript
Angularjs 根据一个select的值去设置另一个select的值方法
2018/08/13 Javascript
vue 项目中使用Loading组件的示例代码
2018/08/31 Javascript
小程序测试后台服务的方法(ngrok)
2019/03/08 Javascript
axios如何利用promise无痛刷新token的实现方法
2019/08/27 Javascript
js实现列表按字母排序
2020/08/11 Javascript
Python 实现 贪吃蛇大作战 代码分享
2016/09/07 Python
python通过socket实现多个连接并实现ssh功能详解
2017/11/08 Python
pytorch 归一化与反归一化实例
2019/12/31 Python
为什么黑客都用python(123个黑客必备的Python工具)
2020/01/31 Python
python上selenium的弹框操作实现
2020/07/13 Python
纯css3制作煽动翅膀的蝴蝶的示例
2018/04/23 HTML / CSS
办公室前台岗位职责
2014/01/04 职场文书
中国在我心中演讲稿
2014/09/13 职场文书
小学教师自我剖析材料
2014/09/29 职场文书
个人存款证明书
2014/10/18 职场文书
博士导师推荐信
2015/03/25 职场文书
2015毕业生实习期工作总结
2015/04/09 职场文书
用人单位聘用意向书
2015/05/11 职场文书
详解Redis在SpringBoot工程中的综合应用
2021/10/16 Redis
解决Springboot PostMapping无法获取数据的问题
2022/05/06 Java/Android
Java实现超大Excel文件解析(XSSF,SXSSF,easyExcel)
2022/07/15 Java/Android