setTimeout、高级监听handler、this.$nextTick

问题:我右侧显示i打开组件,然后将值的改动上传到store,然后左侧进行监听,发现有变动之后执行以下命令,但是结果发现组件窗口正确打开,但是监听没有执行
在这里插入图片描述
请求别人的帮忙学到了this.$nextTick与立即监听,以及自己测试了解了setTimeout的一些性质
this.$nextTick(() => { })

      监视的状态名:{
        handler(a, b) {
           代码块
        },
        deep: true,
        immediate: true,
        }
一. 高级监听handler

这里设定一个监听的对象如 status

1. 普通监听

解决:对象属性改变后执行代码块
问题:刷新或首次加载不能执行

watch:{
	status(val,oldval){
		代码块
	}
}
2. 深度监听

解决:将deep设置为true,即可监听对象数组内部属性的变化
问题:

watch:{
	status:{
	handler(val,oldval)
		代码块
	}
	deep:true
}
3. 立即监听

解决:解决了普通监听刷新或首次加载不能执行的问题
问题:由于从一开始就开始监听,所以有可能对象内部并没有值,需要在代码块加判断或者设置监听时间,如(setTimeout或this.$nextTick)

watch:{
	status:{
	handler(val,oldval)
		代码块
	}
	immediate:true
}
二. this.$nextTick

this.$nextTick(() => { })
解决: 将回调延迟到下次 DOM 更新循环之后执行。在修改数据之后立即使用它,然后等待 DOM 更新。

三. setTimeout 0
setTimeout(()=>{
 console.log('我是setTimeout');
}, 1000);

说明:setTimeout可以设定在某个事件后执行代码
但是它的功能并不局限与某个时间后执行,由于js是单线程的,故需要一个排序,设置了setTimeout后会自动将自己的顺序往后排,所以纯代码块和加了setTimeout的执行结果是不一样的,在某些时候能起到一些意想不到的作用
(以上仅仅是个人的理解)

使用:可以除了上述作用,也可进行函数去抖,进行查询的时候关键词查询的时候来回变化,可以设置一个时间让其执行

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值