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 相关文章推荐
javascript 面向对象思想 附源码
Jul 07 Javascript
js中eval()函数和trim()去掉字符串左右空格应用
Feb 02 Javascript
关于Javascript 对象(object)的prototype
May 09 Javascript
js代码实现点击按钮出现60秒倒计时
Jan 28 Javascript
js右下角弹出提示框示例代码
Jan 12 Javascript
Bootstrap风格的WPF样式
Dec 07 Javascript
ionic+AngularJs实现获取验证码倒计时按钮
Apr 22 Javascript
js中bool值的转换及“&amp;&amp;”、“||”、 “!!”详解
Dec 21 Javascript
详解从买域名到使用pm2部署node.js项目全过程
Mar 07 Javascript
解析vue路由异步组件和懒加载案例
Jun 08 Javascript
layui操作列按钮个数和文字颜色的判断实例
Sep 11 Javascript
JavaScript的垃圾回收机制与内存管理
Aug 06 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
第八节 访问方式 [8]
2006/10/09 PHP
php实现在服务器端调整图片大小的方法
2015/06/16 PHP
PHP二维数组去重实例分析
2016/11/18 PHP
php curl简单采集图片生成base64编码(并附curl函数参数说明)
2019/02/15 PHP
jquery.post用法示例代码
2014/01/03 Javascript
node.js中的fs.truncate方法使用说明
2014/12/15 Javascript
JavaScript替换当前页面的方法
2015/04/03 Javascript
jQuery中的基本选择器用法学习教程
2016/04/14 Javascript
第三章之Bootstrap 表格与按钮功能
2016/04/25 Javascript
jQuery获取file控件中图片的宽高与大小
2016/08/04 Javascript
详解vue 中使用 AJAX获取数据的方法
2017/01/18 Javascript
JavaScript实现打地鼠小游戏
2020/04/23 Javascript
JavaScript实现简单的隐藏式侧边栏功能示例
2018/08/31 Javascript
Node.js对MongoDB进行增删改查操作的实例代码
2019/04/18 Javascript
js Array.slice的8种不同用法示例
2019/07/10 Javascript
JS/CSS实现字符串单词首字母大写功能
2019/09/03 Javascript
[04:59]2018DOTA2亚洲邀请赛 4.7 Mineski夺冠时刻
2018/04/09 DOTA
Python subprocess模块学习总结
2014/03/13 Python
详解Python中的条件判断语句
2015/05/14 Python
Python实现二分查找与bisect模块详解
2017/01/13 Python
使用Python脚本和ADB命令实现卸载App
2017/02/10 Python
Pipenv一键搭建python虚拟环境的方法
2018/05/22 Python
使用Pyinstaller转换.py文件为.exe可执行程序过程详解
2019/08/06 Python
python中有关时间日期格式转换问题
2019/12/25 Python
浅谈django 模型类使用save()方法的好处与注意事项
2020/03/28 Python
HTML5之SVG 2D入门12—SVG DOM及DOM操作介绍
2013/01/30 HTML / CSS
Hotels.com香港酒店网:你的自由行酒店订房专家
2018/01/22 全球购物
文秘自荐信
2013/10/20 职场文书
总经理秘书工作职责
2013/12/26 职场文书
《圆明园的毁灭》教学反思
2014/02/28 职场文书
2014年最新学习全国两会精神心得
2014/03/17 职场文书
九一八事变演讲稿范文
2014/09/14 职场文书
高三复习计划
2015/01/19 职场文书
python实现腾讯滑块验证码识别
2021/04/27 Python
MySQL中VARCHAR与CHAR格式数据的区别
2021/05/26 MySQL
keepalived + nginx 实现高可用方案
2022/12/24 Servers