失眠网,内容丰富有趣,生活中的好帮手!
失眠网 > vue.js中关于$watch的oldvalue与newValue的深入讲解

vue.js中关于$watch的oldvalue与newValue的深入讲解

时间:2021-05-27 13:59:09

相关推荐

vue.js中关于$watch的oldvalue与newValue的深入讲解

web前端|js教程

javascript,newValue,oldvalue

web前端-js教程

这篇文章主要给大家介绍了关于vue.js中$watch的oldvalue与newValue的相关资料,文中通过示例代码介绍的非常详细,并且介绍了关于watch的其他测试,对大家学习或者使用vue.js具有一定的参考学习价值,需要的朋友们下面跟着小编来一起看看吧。

ws 源码,ubuntu12.4密码,一个tomcat多端口,新手爬虫项目,php二分查找原理,西宁seo专家lzw

$watch中的oldvalue和newValue

宾馆网站源码,ubuntu 18 改ip,python爬虫禁用js,算法 php,maj工具seolzw

大家都知道,在vue.js中给我们提供了$watch的方法来做对象变化的监听,而且在callback中会返回两个对象,分别是oldValue和newValue.

上线了 网站源码,vscode代码高亮控件,松下装ubuntu,tomcat部署项目顺序,sqlite数据库操作类,房屋角落有很小的红色小爬虫,php支付宝开发文档,专业seo优化哪个好,国外的app设计网站,ecshop外贸免费模板lzw

顾名思义,这两个对象就是对象发生变化前后的值。

但是在使用过程中我发现这两个值并不总是预期的。下面来一起看看详细的介绍:

定义data的值

data: { arr: [{ name: 笨笨, address: 上海 }, { name: 笨笨熊, address: 北京 }], obj: { name: 呆呆, address: 苏州 }, str: 哈哈哈 }

定义watch

watch: { arr: function(newValue, oldValue) { console.log(newValue, oldValue) console.log(JSON.stringify(oldValue) === JSON.stringify(newValue)) }, obj: function(newValue, oldValue) { console.log(newValue, oldValue) console.log(JSON.stringify(oldValue) === JSON.stringify(newValue)) }, str: function(newValue, oldValue) { console.log(newValue, oldValue) console.log(JSON.stringify(oldValue) === JSON.stringify(newValue)) }, }

定义事件触发

methods: { test() { this.arr.push({ name: 9 }) this.$set(this.obj, i, 0) this.str = \ }, test1() { this.arr = [{ name: 00 }] this.obj = { name: 999 } this.str = 123 } }

测试结果为

对数组进行push操作和对Obj进行$set操作,虽然都可能触发watch事件,但是在callback返回的结果中,oldValue和newValue相同。字符串对象如预期返回

在对数组和Obj统一进行赋值操作时,watch触发并且oldValue和newValue如预期返回

关于watch的其他测试

不能够触发监听的

1、数组

修改某个下标的某个属性的值

使用原生delete删除某个属性

对某个下标新增一个属性(不使用$set)

对某个下标重新赋值

2、对象

修改某个属性的值(但是会触发这个属性的监听)

新增一个属性(不使用$set)

原生delete删除某个属性

以上总结可能存在不足

万金油实现watch监听

在修改完数据后添加这样一段代码

array

arr = [...arr]

obj

obj = {...obj}

总结

如果觉得《vue.js中关于$watch的oldvalue与newValue的深入讲解》对你有帮助,请点赞、收藏,并留下你的观点哦!

本内容不代表本网观点和政治立场,如有侵犯你的权益请联系我们处理。
网友评论
网友评论仅供其表达个人看法,并不表明网站立场。