深入理解vue.js中$watch的oldvalue与newValue

发布时间 - 2026-01-11 02:40:27    点击率:

$watch中的oldvalue和newValue

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

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

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

定义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: '000'
  }]
  this.obj = {
  name: 999
  }
  this.str = '123'
 }
 }

测试结果为

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

关于watch的其他测试

不能够触发监听的

1、数组

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

        使用原生delete删除某个属性

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

        对某个下标重新赋值

2、对象

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

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

        原生delete删除某个属性

以上总结可能存在不足

万金油实现watch监听

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

array

arr = [...arr]

obj

obj = {...obj}

总结

以上就是这篇文章的全部内容了,希望本文的内容对大家的学习或者工作能带来一定的帮助,如果有疑问大家可以留言交流,谢谢大家对的支持。


# vue  # watch  # oldvalue  # oldval  # old  # 实例详解vue.js浅度监听和深度监听及watch用法  # vue.js使用watch监听路由变化的方法  # Vue.js中关于侦听器(watch)的高级用法示例  # Vue.js 中的 $watch使用方法  # Vue.Js中的$watch()方法总结  # Vue.js计算属性computed与watch(5)  # vue.js中$watch的用法示例  # Vue.js 的 watch函数基本用法  # 这两个  # 但是在  # 大家都  # 给我们  # 苏州  # 在对  # 顾名思义  # 这篇文章  # 来做  # 谢谢大家  # 不能够  # 北京  # 上海  # 中会  # 过程中  # 我发现  # 笨笨熊  # 有疑问  # callback 


相关栏目: 【 网站优化151355 】 【 网络推广146373 】 【 网络技术251813 】 【 AI营销90571


相关推荐: 西安市网站制作公司,哪个相亲网站比较好?西安比较好的相亲网站?  java中使用zxing批量生成二维码立牌  非常酷的网站设计制作软件,酷培ai教育官方网站?  javascript中闭包概念与用法深入理解  郑州企业网站制作公司,郑州招聘网站有哪些?  如何在IIS服务器上快速部署高效网站?  家族网站制作贴纸教程视频,用豆子做粘帖画怎么制作?  网站制作壁纸教程视频,电脑壁纸网站?  如何快速辨别茅台真假?关键步骤解析  js实现点击每个li节点,都弹出其文本值及修改  UC浏览器如何设置启动页 UC浏览器启动页设置方法  个人摄影网站制作流程,摄影爱好者都去什么网站?  Python文件异常处理策略_健壮性说明【指导】  LinuxShell函数封装方法_脚本复用设计思路【教程】  JavaScript实现Fly Bird小游戏  Laravel如何处理跨站请求伪造(CSRF)保护_Laravel表单安全机制与令牌校验  如何快速生成ASP一键建站模板并优化安全性?  如何自定义safari浏览器工具栏?个性化设置safari浏览器界面教程【技巧】  微信小程序制作网站有哪些,微信小程序需要做网站吗?  Laravel如何实现RSS订阅源功能_Laravel动态生成网站XML格式订阅内容【教程】  Laravel事件和监听器如何实现_Laravel Events & Listeners解耦应用的实战教程  java获取注册ip实例  Laravel如何为API编写文档_Laravel API文档生成与维护方法  油猴 教程,油猴搜脚本为什么会网页无法显示?  简单实现Android验证码  怎么用AI帮你设计一套个性化的手机App图标?  Laravel如何与Vue.js集成_Laravel + Vue前后端分离项目搭建指南  北京网页设计制作网站有哪些,继续教育自动播放怎么设置?  千库网官网入口推荐 千库网设计创意平台入口  Laravel如何创建自定义中间件?(Middleware代码示例)  七夕网站制作视频,七夕大促活动怎么报名?  如何在Windows 2008云服务器安全搭建网站?  Laravel怎么实现验证码(Captcha)功能  Android自定义控件实现温度旋转按钮效果  如何快速搭建高效WAP手机网站?  Laravel的.env文件有什么用_Laravel环境变量配置与管理详解  如何在宝塔面板创建新站点?  详解jQuery中基本的动画方法  昵图网官网入口 昵图网素材平台官方入口  Linux虚拟化技术教程_KVMQEMU虚拟机安装与调优  Python并发异常传播_错误处理解析【教程】  javascript中对象的定义、使用以及对象和原型链操作小结  如何在阿里云完成域名注册与建站?  Midjourney怎么调整光影效果_Midjourney光影调整方法【指南】  高防服务器租用指南:配置选择与快速部署攻略  HTML 中如何正确使用模板变量为元素的 name 属性赋值  Laravel如何操作JSON类型的数据库字段?(Eloquent示例)  在线制作视频的网站有哪些,电脑如何制作视频短片?  详解Oracle修改字段类型方法总结  网页设计与网站制作内容,怎样注册网站?