vue开发技巧——watch使用

watch 使用

想必大家在vue开发中都或多或少的都会使用到watch来监听数据的变化,那我们就来聊一聊watch方法。

那我们大家都知道watch可以监听data中的数据变化:

watch:{
	value:function(newVal,oldVal){
		...do something
	}
}
methods:{
	valueChange(newVal,oldVal){
		...do something
	}
},
watch:{
	value:'valueChange'
}

如上两种方法都可以实现我们的监听需求,同样也是我们普遍的用法,但当我们所监听的vaule值变为一个object对象时,显然,上面的使用已经满足不了我们的需求了。

那我们可以直接修改需求吗,显然不能;如果能,我们也不能这么做;所以我们只能来修改我们的使用方法来满足需求。

deep

那假设我们有一个对象为**{id:‘1’,name:‘cb’}**,那我们要监听对象中id,和name的变化,并做一些处理。

data(){
	return {
		Object:{
			id:'1',
			name:'cb'
		}
	}
},
watch:{
	Object:{
		handler(newVal,oldVal){
			...do something
		},
		deep:true
	}
}

那这样就可以满足我们的需求了,这就是deep属性,deep属性会对目标深度监听。

那如果我们只想监听对象的 id或者name,那我们上面的写法是不是就有些浪费了呢。我们也可以单独对对象的某个属性来监听。

watch:{
	'Object.id':{
		handler(newVal,oldVal){
			...do something
		},
	},
	'Object.name':{
		handler(newVal,oldVal){
			...do something
		}
	}
}

immediate

在使用wacth 的监听中,组件初始化时,并不会执行wacth 中的handler方法,那么immediate属性就要登场了。

watch:{
	value:{
		handler(newVal,oldVal){
			...do something
		},
		immediate:true
	}
}

immediate 设为true时,组件初始化就会执行一次handler,灵活运用来满足需求。

提示

数组的变化不需要通过深度监听,对象数组中对象的属性变化则需要deep深度监听。

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值