vue的watch问题

image.png

image.png

image.png

image.png

这里的watch中获取到的newVal和oldVal都是同一个内存地址,现在要怎么才能实现获取到原来的值呢,我知道可以通过监听对象的某个属性来获取,但是如果是要监听newobj里面的多个属性呢,难道我要写多个对象中的键的监听嘛

阅读 2.3k
2 个回答

是的,如果想知道对象属性原来的值,确实是需要监听对象的多个属性来获取到。

赋值的时候不要直接改属性,而是duplicate一个再整个替换,这样vue才能知道是整个obj变了

var tmp = JSON.parse(JSON.stringify(this.newobj))
tmp.b = '4'
this.newobj = tmp
撰写回答
你尚未登录,登录后可以
  • 和开发者交流问题的细节
  • 关注并接收问题和回答的更新提醒
  • 参与内容的编辑和改进,让解决方法与时俱进
推荐问题