data中对象新增属性或者数组数据更新,页面不渲染

在vue实例化的时候会对data对象中的属性进行递归,然后进行监听,给对象新增一个属性,vue不会对其新增属性的getter和sertter进行监听,所以不能实现数据双向绑定
数据双向绑定原理:采用数据劫持结合发布者-订阅者模式实现数据双向绑定,数据劫持主要是通过Object.defineProperty()劫持属性的getter和setter操作进行监听数据变化,如果数据变化,则发出通知
解决办法:
可以使用 Vue.set(target,key,value) 或 this.$set(target,key,value)
target事件源(对象或数组),key(属性或索引),value(值)

你可能感兴趣的:(data中对象新增属性或者数组数据更新,页面不渲染)