<li v-for="item in obj">{{ item }}</li>
  • 1.
obj = {
   a: 123,
   b: 223,
   c: 323
}
  • 1.
  • 2.
  • 3.
  • 4.
  • 5.

此时若在methods中使用 delete this.obj.a 或者 delete this.obj[“a”]会发现视图中的li不会实时更新,这种情况是由于原生delete并不能被vue检测到变化

解决办法: 使用 Vue.delete 代替 delete,这样就可以让vue捕捉到这一变化从而更新视图 操作代码:

this.$delete(this.obj, "a")
  • 1.

参考:

vue中detele删除对象属性时视图不能响应更新 - 解决办法