1.视图不更新情况一
数组数据变动:我们使用某些方法操作数组,变动数据时,有些方法无法被vue监测,有些可以
push()
pop()
shift()
unshift()
splice()
sort()
reverse()
filter()
concat()
slice()
这些不会改变原始数组,但总是返回一个新数组。当使用非变异方法时,可以用新数组替换旧数组
Vue 不能检测以下变动的数组:
① 当你利用索引直接设置一个项时,vm.items[indexOfItem] = newValue
② 当你修改数组的长度时,例如: vm.items.length = newLength
2.视图不更新情况二
第二种视图不更新情况是Vue?不能检测到对象属性的添加或删除。由于 Vue 会在初始化实例时对属性执行?getter/setter?转化过程,所以属性必须在?data?对象上存在才能让 Vue 转换它,这样才能让它是响应的
然而它可以使用Vue.set(object, key, value)方法将响应属性添加到嵌套的对象上
Vue.set(vm.someObject, ‘b’, 2)
或者
this.$set(this.someObject,‘b’,2) (这也是全局Vue.set方法的别名)