vue  directive定义全局和局部指令及指令简写


Posted in Javascript onNovember 20, 2018

directive定义全局和局部指令以及指令简写

1.使用Vue.directive()定义一个全局指令    Vue.directive('指令名称',{对象})
2.参数一:指令的名称,定义时指令前面不需要写v-
3.参数二:是一个对象,该对象中有相关的操作函数
4.在调用的时候必须写v-
5.自定义指令中的常用的3个钩子函数:
    5.1bind:
      1.指令绑定到元素上回立刻执行bind函数,只执行一次
      2.每个函数中第一个参数永远是el,表示绑定指令的元素,el参数是原生js对象
      3.通过el.focus()是无法获取焦点的,因为只有插入DOM后才生效
    5.2inserted:
      1.inserted表示一个元素,插入到DOM中会执行inserted函数,只触发一次
    5.3updated:
      1.当VNode更新的时候会执行updated,可以触发多次
6.定义一个局部指令

    测试案例步骤:

    1.首先需要在html中创建一个盒子

    2.接着需要通过实例化Vue并且通过el将盒子所对应的id进行绑定

    3.在盒子里面所对应的要自定义的标签上通过v-xxx标注

    局部定义的格式:

directives:{
      'xxx':{
       bind:function(el,binding){
        el.style.xxx = binding.value
      }
     }
   }

 7.指令函数的简写

    function等同于将代码写入bind和update里

directive:{  
    'xxx':function(el,binding){
      el.style.xxx = binding.value
    }
  }
<!DOCTYPE html>
<html>
 <head>
   <meta charset="utf-8" />
   <title></title>
   <script src="js/vue-2.4.0.js" type="text/javascript" charset="utf-8"></script>
 </head>
 <body>
   <div id="box">
     <p v-fontsize="'20px'" v-color="'green'">{{msg}}<input type="text" v-focus /></p>
     <p v-color="'red'">{{msg}}<input type="text" v-color="'red'" /></p>
   </div>
 </body>
 <script type="text/javascript">
   //使用Vue.directive()定义一个全局指令
   //1.参数一:指令的名称,定义时指令前面不需要写v-
   //2.参数二:是一个对象,该对象中有相关的操作函数
   //3.在调用的时候必须写v-
   Vue.directive('focus',{
     //1.指令绑定到元素上回立刻执行bind函数,只执行一次
     //2.每个函数中第一个参数永远是el,表示绑定指令的元素,el参数是原生js对象
     //3.通过el.focus()是无法获取焦点的,因为只有插入DOM后才生效
     bind:function(el){
       //el.focus()
     },
     //inserted表示一个元素,插入到DOM中会执行inserted函数,只触发一次
     inserted:function(el){
       el.focus()
     },
     //当VNode更新的时候会执行updated,可以触发多次
     updated:function(el){
       //el.focus()
     }
   })
   //自定义一个设置字体颜色指令
   Vue.directive('color',{
     //只要通过指令绑定给了元素,元素一定会显示在页面上
     //一般情况和样式有关的使用bind函数
     bind:function(el,binding){ //通过binding来传递值
       el.style.color = binding.value
     }
   })
   //实例化Vue
   var vm = new Vue({
     el:'#box',
     data:{
       msg:'测试:'
     },
     //定义一个局部指令
     directives:{ //自定义一个局部指令
       'color':{ //设置字体颜色
         bind:function(el,binding){
           el.style.color = binding.value
         }
       },
       //指令函数的简写:
       //function等同于将代码写入bind和update里
       'fontsize':function(el,binding){ //设置字体大小
         el.style.fontSize = parseInt(binding.value) + 'px' 
       }
     }
   })
 </script>
</html>

总结

以上所述是小编给大家介绍的vue  directive定义全局和局部指令及指令简写,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对三水点靠木网站的支持!

Javascript 相关文章推荐
JQuery跨Iframe选择实现代码
Aug 19 Javascript
获取offsetTop和offsetLeft值的js代码(兼容)
Apr 16 Javascript
JS模拟酷狗音乐播放器收缩折叠关闭效果代码
Oct 29 Javascript
JavaScript面向对象之私有静态变量实例分析
Jan 14 Javascript
JS打印组合功能
Aug 04 Javascript
JavaScript &amp; jQuery完美判断图片是否加载完毕
Jan 08 Javascript
Bootstrap中glyphicons-halflings-regular.woff字体报404错notfound的解决方法
Jan 19 Javascript
微信小程序 基础知识css样式media标签
Feb 15 Javascript
原生JS改变透明度实现轮播效果
Mar 24 Javascript
js实现倒计时关键代码
May 05 Javascript
微信小程序使用progress组件实现显示进度功能【附源码下载】
Dec 12 Javascript
bootstrap fileinput插件实现预览上传照片功能
Jan 23 Javascript
详解Vue.js在页面加载时执行某个方法
Nov 20 #Javascript
element vue validate验证名称重复 输入框与后台重复验证 特殊字符 字符长度 及注意事项小结【实例代码】
Nov 20 #Javascript
jQuery 同时获取多个标签的指定内容并储存为数组
Nov 20 #jQuery
一步步教你利用Docker设置Node.js
Nov 20 #Javascript
JS滚轮控制图片缩放大小和拖动的实例代码
Nov 20 #Javascript
vue中的适配px2rem示例代码
Nov 19 #Javascript
JS监听事件的叠加和移除功能
Nov 19 #Javascript
You might like
php向js函数传参的几种方法
2014/08/10 PHP
PHP微信开发之有道翻译
2016/06/23 PHP
JavaScript 异步调用框架 (Part 2 - 用例设计)
2009/08/03 Javascript
JavaScript isArray()函数判断对象类型的种种方法
2010/10/11 Javascript
jQuery EasyUI API 中文文档 - DataGrid数据表格
2011/11/17 Javascript
JavaScript高级程序设计(第3版)学习笔记8 js函数(中)
2012/10/11 Javascript
禁止你的左键复制实用技巧
2013/01/04 Javascript
IE6下opacity与JQuery的奇妙结合
2013/03/01 Javascript
JS中Iframe之间传值的方法
2013/03/11 Javascript
使用jQuery清空file文件域的解决方案
2013/04/12 Javascript
读取input:file的路径并显示本地图片的方法
2013/09/23 Javascript
js实现双击图片放大单击缩小的方法
2015/02/17 Javascript
基于js实现投票的实例代码
2015/08/04 Javascript
js实现简洁的TAB滑动门效果代码
2015/09/06 Javascript
JavaScript多并发问题如何处理
2015/10/28 Javascript
javascript中不易分清的slice,splice和split三个函数
2016/03/29 Javascript
Javascript简写条件语句(推荐)
2016/06/12 Javascript
AngularJS 输入验证详解及实例代码
2016/07/28 Javascript
jQuery select自动选中功能实现方法分析
2016/11/28 Javascript
使用typescript开发angular模块并发布npm包
2018/04/19 Javascript
详解Vue实战指南之依赖注入(provide/inject)
2018/11/13 Javascript
JavaScript中this的学习笔记及用法整理
2020/02/17 Javascript
微信小程序后端无法保持session的原因及解决办法问题
2020/03/20 Javascript
js实现缓动动画
2020/11/25 Javascript
Python之使用adb shell命令启动应用的方法详解
2019/01/07 Python
对python3中, print横向输出的方法详解
2019/01/28 Python
Pyqt5 实现跳转界面并关闭当前界面的方法
2019/06/19 Python
python创建n行m列数组示例
2019/12/02 Python
python实现人像动漫化的示例代码
2020/05/17 Python
Bonami斯洛伐克:购买家具和家居饰品
2019/07/02 全球购物
党的群众路线教育实践活动批评与自我批评
2014/02/16 职场文书
国际经济与贸易专业大学生职业规划书
2014/03/01 职场文书
2014财务部年度工作总结
2014/12/08 职场文书
《我是什么》教学反思
2016/02/16 职场文书
golang 实现时间戳和时间的转化
2021/05/07 Golang
openstack云计算keystone组件工作介绍
2022/04/20 Servers