Vue自定义指令和钩子函数

Vue自定义指令

应用场景

需要在页面刷新或者进入时就立即在指定位置获取鼠标焦点

自定义指令和钩子函数

定义时不需要v-但调用时需要

和行为相关的操作一般放在inserted中执行
<label>请输入搜索的关键字:<input type="text" class="form-control" v-model="keywords" v-focus></label>
Vue.directive('focus',{
			bind:function(){}//每当指令绑定到元素上的时候,会立即执行,并只执行一次
			inserted:function(el){
				el.focus()
			}//元素插入DOM中的时候执行
			updated:function(){}//当VNode更新的时候执行
		})
和样式相关的操作一般放在bind中执行
<label>请输入搜索的关键字:<input type="text" class="form-control" v-model="keywords" v-color></label>
Vue.directive('colorRed',{
			bind:function(el){
			el.style.color = 'red'//元素将获得内联样式不管这时是否插入到页面
			}//每当指令绑定到元素上的时候,会立即执行,并只执行一次
			inserted:function(){
			}//元素插入DOM中的时候执行
			updated:function(){}//当VNode更新的时候执行
		})

钩子函数的参数

第一个参数:el:指令绑定的元素,可以用来直接操作DOM
第二个参数:一个对象,包含以下属性:
name:指令名,不包括-v前缀
value:指令的绑定值。
oldValue:指令绑定的前一个值
expression:绑定值的字符串形式
arg:传给指令的参数
modifiers:一个包含修饰符的对象

binding参数使用
<label>请输入搜索的关键字:<input type="text" class="form-control" v-model="keywords" v-color="'yellow'"></label>
Vue.directive('colorRed',{
			bind:function(el, binding){
			el.style.color = binding.value//元素将获得内联样式不管这时是否插入到页面
			}//每当指令绑定到元素上的时候,会立即执行,并只执行一次
			inserted:function(){
			}//元素插入DOM中的时候执行
			updated:function(){}//当VNode更新的时候执行
		})

私有化指令

把指令放到某个Vue实例中

缩写

省略全部钩子函数等同于把代码写到了bind和update中去

Vue.directive('colorRed', function(el, binding) {
			el.style.color = binding.value
		})
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值