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 CSS 修改学习第四章 透明度设置
Feb 19 Javascript
JavaScript闭包函数访问外部变量的方法
Aug 27 Javascript
JS实现仿新浪微博发布内容为空时提示功能代码
Aug 19 Javascript
Windows环境下npm install 报错: operation not permitted, rename的解决方法
Sep 26 Javascript
让编辑器支持word复制黏贴、截屏的js代码
Oct 17 Javascript
setTimeout学习小结
Feb 08 Javascript
angular.js + require.js构建模块化单页面应用的方法步骤
Jul 19 Javascript
js中json对象和字符串的理解及相互转化操作实现方法
Sep 22 Javascript
vue项目中使用AES实现密码加密解密(ECB和CBC两种模式)
Aug 12 Javascript
微信小程序 wx:for 与 wx:for-items 与 wx:key的正确用法
May 19 Javascript
vue实现图片上传功能
May 28 Javascript
使用Ajax实现无刷新上传文件
Apr 12 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弹出提示框并跳转到新页面即重定向到新页面
2014/01/24 PHP
php使用gzip压缩传输js和css文件的方法
2015/07/29 PHP
Laravel中注册Facades的步骤详解
2016/03/16 PHP
PHP中session跨子域的三种实现方法
2016/07/25 PHP
JavaScript快速检测浏览器对CSS3特性的支持情况
2012/09/26 Javascript
使用nodejs开发cli项目实例
2015/06/03 NodeJs
解决jquery中动态新增的元素节点无法触发事件问题的两种方法
2015/10/30 Javascript
逻辑表达式中与或非的用法详解
2016/06/06 Javascript
JS实现二维数组横纵列转置的方法
2018/04/17 Javascript
如何手动实现es5中的bind方法详解
2018/12/07 Javascript
用npm-run实现自动化任务的方法示例
2019/01/14 Javascript
Vue 中可以定义组件模版的几种方式
2019/08/06 Javascript
Vue表单控件数据绑定方法详解
2020/02/05 Javascript
JS实现图片幻灯片效果代码实例
2020/05/21 Javascript
vue路由权限校验功能的实现代码
2020/06/07 Javascript
Nodejs环境实现socket通信过程解析
2020/07/03 NodeJs
vue编写简单的购物车功能
2021/01/08 Vue.js
[00:43]TI7不朽珍藏III——幽鬼不朽展示
2017/07/15 DOTA
python实现堆栈与队列的方法
2015/01/15 Python
python使用cStringIO实现临时内存文件访问的方法
2015/03/26 Python
Python中的类与对象之描述符详解
2015/03/27 Python
python中字典(Dictionary)用法实例详解
2015/05/30 Python
Python使用flask框架操作sqlite3的两种方式
2018/01/31 Python
Python切片操作去除字符串首尾的空格
2019/04/22 Python
python with语句的原理与用法详解
2020/03/30 Python
REISS英国官网:伦敦High Street最受欢迎品牌
2016/12/21 全球购物
优衣库澳大利亚官网:UNIQLO澳大利亚
2017/01/18 全球购物
数控机床专业自荐信
2014/05/19 职场文书
《爱的教育》读书心得
2014/11/08 职场文书
民事和解协议书格式
2014/11/29 职场文书
2015年远程教育工作总结
2015/05/20 职场文书
《游戏公平》教学反思
2016/02/20 职场文书
《折线统计图》教学反思
2016/02/22 职场文书
python中Tkinter 窗口之输入框和文本框的实现
2021/04/12 Python
python基于tkinter实现gif录屏功能
2021/05/19 Python
python实现A*寻路算法
2021/06/13 Python