3-13 直接给一个数组项赋值,Vue 能检测到变化吗?
由于 JavaScript 的限制,Vue2 不能检测到以下数组的变动:
- 当你利用索引直接设置一个数组项时,例如: vm.items[indexOfItem] = newValue
- 当你修改数组的长度时,例如: vm.items.length = newLength
为了解决第一个问题,Vue 提供了以下操作方法:
通过索引来修改数组,使其能成为响应式,解决直接使用赋值不能响应的问题
Vue.$set(vm.data,2,‘huanpu’,‘name’) 对数组
Vue.$set(vm.data,‘K’,‘V’) 对对象
为了解决第二个问题,Vue 提供了以下操作方法:
vm.items.splice(newLength)
但是如果你使用的是vue3 就已经不存在这个问题了

浙公网安备 33010602011771号