使用场景:在vue中,当你需要修改某个对象的属性,并且需要确保这个属性是双向绑定的,那么就需要使用this.$set()方法,进行强制视图更新。
this.$set()是绑定在vue的.prototype原型上,vue是使用Object.defineProperty给对象做了一层拦截,当触发get时进行依赖收集,当触发set时触发依赖导致渲染函数执行重新渲染。第一次触发get是在首次加载页面渲染的时候触发,就会递归的将对象的属性都依赖收集。而我们修改对象新加的属性不是对象已有属性,并未进行依赖收集,所以导致不会重新渲染。
调用方法: this.$set( target , key , value)
target: 要更改的数据源(可以是一个对象或者数组)
key 要更改的具体数据 (索引)
value 重新赋的值