vue3使用reactive包裹數(shù)組正確賦值問(wèn)題
使用reactive包裹數(shù)組正確賦值
需求:將接口請(qǐng)求到的列表數(shù)據(jù)賦值給響應(yīng)數(shù)據(jù)arr
const arr = reactive([]); const load = () => { const res = [2, 3, 4, 5]; //假設(shè)請(qǐng)求接口返回的數(shù)據(jù) // 方法1 失敗,直接賦值丟失了響應(yīng)性 // arr = res; // 方法2 這樣也是失敗 // arr.concat(res); // 方法3 可以,但是很麻煩 res.forEach(e => { arr.push(e); }); };
vue3使用proxy
,對(duì)于對(duì)象和數(shù)組都不能直接整個(gè)賦值。
使用方法1能理解,直接賦值給用reactive
包裹的對(duì)象也不能這么做。
方法2為什么不行?
只有push或者根據(jù)索引遍歷賦值才可以保留reactive數(shù)組的響應(yīng)性?
如何方便的將整個(gè)數(shù)組拼接到響應(yīng)式數(shù)據(jù)上?
提供幾種辦法
const state = reactive({ arr: [] }); state.arr = [1, 2, 3]
或者
const state = ref([]) state.value = [1, 2, 3]
或者
const arr = reactive([]) arr.push(...[1, 2, 3])
這幾種辦法都可以觸發(fā)響應(yīng)性,推薦第一種
vue3的reactive重新賦值無(wú)效
vue3官方的文檔說(shuō)明
reactive() 返回一個(gè)對(duì)象的響應(yīng)式代理
所以 reactive 方法應(yīng)該作用于一個(gè)對(duì)象Object,如果要使用數(shù)組,則需要包裝一下:
let list = reactive({ ?? ?data: [{id: 01, name: 'XXX'}] })
或者使用 ref:
let list = ref([{id: 1, name: 'Andy'}])
已下引用原作者的代碼:
import { reactive, ref } from 'vue' export default { ? setup() { ? ? // 需要一個(gè)帶默認(rèn)值的數(shù)組list; ? ?? ?let list = reactive([{id: 1, name: 'Andy'}]) ? ?? ? ? // 每次觸發(fā)事件重置list,把新值放入,此種方式不會(huì)觸發(fā)視圖更新 ? ? const checkBtn = () => { ? ? ? // 此時(shí)重置操作 地址指向變成一個(gè)新的地址,不會(huì)觸發(fā)視圖更新 ? ? ? list = [{id: 1, name: 'Andy'}] ? ? ? list.push({id: 2, name: 'Lucy'}) ? ? } ? ?? ? ? // -------------------------------------------------- ? ? // 正確的重置處理方法如下:使用reactive將數(shù)組包裹到一個(gè)對(duì)象中 ? ? let list = reactive({ ? ? ? data: [{id: 1, name: 'Andy'}] ? ? }); ? ? const checkBtn = () => { ? ? ? list.data = [{id: 1, name: 'Andy'}] ? ? ? list.data.push({id: 2, name: 'Lucy'}) ? ? } ? ? // 或者使用ref ? ? let list = ref([{id: 1, name: 'Andy'}]); ? ? const checkBtn = () => { ? ? ? list.value = [{id: 1, name: 'Andy'}] ? ? ? list.value.push({id: 2, name: 'Lucy'}) ? ? } ? ? return { ? ? ? list, ? ? ? checkBtn ? ? } ? }, }
總結(jié)
以上為個(gè)人經(jīng)驗(yàn),希望能給大家一個(gè)參考,也希望大家多多支持腳本之家。
- vue3的reactive賦值問(wèn)題解決
- Vue3中reactive變量重新賦值無(wú)法響應(yīng)的3種處理方法
- vue3 reactive定義的引用類(lèi)型直接賦值導(dǎo)致數(shù)據(jù)失去響應(yīng)式問(wèn)題
- vue3使用reactive賦值后頁(yè)面不改變
- Vue3 reactive響應(yīng)式賦值頁(yè)面不渲染的解決
- vue3中reactive數(shù)據(jù)被重新賦值后無(wú)法雙向綁定的解決
- vue3中reactive不能直接賦值的解決方案
- 關(guān)于vue3中的reactive賦值問(wèn)題
- vue3 reactive 請(qǐng)求接口數(shù)據(jù)賦值后拿不到的問(wèn)題及解決方案
相關(guān)文章
Vue實(shí)現(xiàn)簡(jiǎn)易計(jì)算器
這篇文章主要為大家詳細(xì)介紹了用Vue制作的簡(jiǎn)易計(jì)算器,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2020-02-02vue@cli3項(xiàng)目模板怎么使用public目錄下的靜態(tài)文件
這篇文章主要介紹了vue@cli3項(xiàng)目模板怎么使用public目錄下的靜態(tài)文件,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2020-07-07Vue子組件如何修改父組件數(shù)據(jù)的方法及注意事項(xiàng)
這篇文章主要介紹了Vue子組件如何修改父組件數(shù)據(jù)的方法及注意事項(xiàng),具有很好的參考價(jià)值,希望對(duì)大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2024-06-06vue項(xiàng)目百度地圖如何自定義標(biāo)注marker
這篇文章主要介紹了vue項(xiàng)目百度地圖如何自定義標(biāo)注marker問(wèn)題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2024-03-03Vue2.0表單校驗(yàn)組件vee-validate的使用詳解
本篇文章主要介紹了Vue2.0表單校驗(yàn)組件vee-validate的使用詳解,詳細(xì)的介紹了vee-validate使用教程。具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2017-05-05vue2.x中keep-alive源碼解析(實(shí)例代碼)
Keep-Alive模式避免頻繁創(chuàng)建、銷(xiāo)毀鏈接,允許多個(gè)請(qǐng)求和響應(yīng)使用同一個(gè)HTTP鏈接,這篇文章主要介紹了vue2.x中keep-alive源碼解析,需要的朋友可以參考下2023-02-02