vue3中给数组赋值丢失响应式怎么解决
vue3给数组赋值丢失响应式的解决
由于vue3使用proxy,对于对象和数组都不能直接整个赋值。
只有push或者根据索引遍历赋值才可以保留reactive数组的响应性
const arr = reactive([]);
const load = () => {
const res = [2, 3, 4, 5]; //假设请求接口返回的数据
// 方法1 失败,直接赋值丢失了响应性
// arr = res;
// 方法2 这样也是失败
// arr.concat(res);
// 方法3 可以,但是很麻烦
res.forEach(e => {
arr.push(e);
});
// 方法4 可以
// arr.length = 0 // 清空原数组
arr.push(...res)
}或者
const state = reactive({
arr: []
});
...
state.arr = res
...或者
const state = ref([]); ... state.value= res ...
例子
...{{ list }}
效果图:

reactive响应式数据赋值丢失响应式问题
reactive响应式数据赋值问题
const list = reactive({})当你接收到接口数据,不要直接赋值 比如 list = data
这样会丢失响应式!
你可以这样做:
const list = reactive({
arr:[]
})
list.arr = data.arr或者
将list声明为ref方式
const list = ref([]) list.value = data
这样也不会丢失响应式
原因:reactive声明的响应式对象被list代理 操作代理对象需要有代理对象的前缀,直接覆盖会丢失响应式