directive定义全局和局部指令以及指令简写
1.使用Vue.directive()定义一个全局指令 Vue.directive('指令名称',{对象})
2.参数一:指令的名称,定义时指令前面不需要写v-
3.参数二:是一个对象,该对象中有相关的操作函数
4.在调用的时候必须写v-
5.自定义指令中的常用的3个钩子函数:
5.1bind:
1.指令绑定到元素上回立刻html" target="_blank">执行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定义全局和局部指令及指令简写,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对小牛知识库网站的支持!
本文向大家介绍vue自定义指令directive实例详解,包括了vue自定义指令directive实例详解的使用技巧和注意事项,需要的朋友参考一下 下面给大家介绍vue自定义指令directive,具体内容如下所示: 官网截图实例 vue除了一些核心的内部定义的指令(v-model,v-if,v-for,v-show)外,vue也允许用户注册自己的一些功能性的指令,有时候你实在是要对Dom操作
本文向大家介绍Vue指令指令大全,包括了Vue指令指令大全的使用技巧和注意事项,需要的朋友参考一下 1. v-text v-text主要用来更新textContent,可以等同于JS的text属性。 这两者等价: 2. v-html 双大括号的方式会将数据解释为纯文本,而非HTML。为了输出真正的HTML,可以用v-html指令。它等同于JS的innerHtml属性。 这个div的内容将会替换成属
本文向大家介绍vue自定义指令directive的使用方法,包括了vue自定义指令directive的使用方法的使用技巧和注意事项,需要的朋友参考一下 Vue中内置了很多的指令,如v-model、v-show、v-html等,但是有时候这些指令并不能满足我们,或者说我们想为元素附加一些特别的功能,这时候,我们就需要用到vue中一个很强大的功能了—自定义指令。 在开始之前,我们需要明确一点,自定义指
本文向大家介绍使用use注册Vue全局组件和全局指令的方法,包括了使用use注册Vue全局组件和全局指令的方法的使用技巧和注意事项,需要的朋友参考一下 Vue中的组件和指令分为局部组件、局部指令和全局组件、全局指令。对于注册有一定数量的全局指令和全局组件时,官方文档中的方法就显得有些不够清爽了。 全局组件 在Vue官方文档中介绍的是使用Vue.component(tagName, options)
简介 除了默认设置的核心指令( v-model 和 v-show ),Vue 也允许注册自定义指令。注意,在 Vue2.0 里面,代码复用的主要形式和抽象是组件——然而,有的情况下,你仍然需要对纯 DOM 元素进行底层操作,这时候就会用到自定义指令。下面这个例子将聚焦一个 input 元素,像这样: Vue.directive('focus', { inserted: function (el)