欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

vue3使用reactive包裹數(shù)組正確賦值問(wèn)題

 更新時(shí)間:2023年03月04日 14:22:40   作者:吳冬雪~  
這篇文章主要介紹了vue3使用reactive包裹數(shù)組正確賦值問(wèn)題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教

使用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è)參考,也希望大家多多支持腳本之家。

相關(guān)文章

  • .env在mode文件中如何添加注釋詳解

    .env在mode文件中如何添加注釋詳解

    這篇文章主要為大家介紹了.env在mode文件中如何添加注釋詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪
    2022-09-09
  • Vue實(shí)現(xiàn)簡(jiǎn)易計(jì)算器

    Vue實(shí)現(xiàn)簡(jiǎn)易計(jì)算器

    這篇文章主要為大家詳細(xì)介紹了用Vue制作的簡(jiǎn)易計(jì)算器,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2020-02-02
  • vue@cli3項(xiàng)目模板怎么使用public目錄下的靜態(tài)文件

    vue@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-07
  • Vue子組件如何修改父組件數(shù)據(jù)的方法及注意事項(xiàng)

    Vue子組件如何修改父組件數(shù)據(jù)的方法及注意事項(xiàng)

    這篇文章主要介紹了Vue子組件如何修改父組件數(shù)據(jù)的方法及注意事項(xiàng),具有很好的參考價(jià)值,希望對(duì)大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2024-06-06
  • vue項(xiàng)目百度地圖如何自定義標(biāo)注marker

    vue項(xiàng)目百度地圖如何自定義標(biāo)注marker

    這篇文章主要介紹了vue項(xiàng)目百度地圖如何自定義標(biāo)注marker問(wèn)題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2024-03-03
  • 搭建vscode+vue環(huán)境的詳細(xì)教程

    搭建vscode+vue環(huán)境的詳細(xì)教程

    這篇文章主要介紹了搭建vscode+vue環(huán)境的詳細(xì)教程,本文通過(guò)圖文并茂的形式給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下
    2020-08-08
  • Vue2.0表單校驗(yàn)組件vee-validate的使用詳解

    Vue2.0表單校驗(yàn)組件vee-validate的使用詳解

    本篇文章主要介紹了Vue2.0表單校驗(yàn)組件vee-validate的使用詳解,詳細(xì)的介紹了vee-validate使用教程。具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2017-05-05
  • Vue框架和前后端開(kāi)發(fā)詳解

    Vue框架和前后端開(kāi)發(fā)詳解

    這篇文章主要為大家介紹了Vue框架和前后端開(kāi)發(fā),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下,希望能夠給你帶來(lái)幫助
    2021-12-12
  • vue實(shí)現(xiàn)防抖的實(shí)例代碼

    vue實(shí)現(xiàn)防抖的實(shí)例代碼

    這篇文章主要給大家介紹了關(guān)于vue實(shí)現(xiàn)防抖的相關(guān)資料,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧
    2021-01-01
  • vue2.x中keep-alive源碼解析(實(shí)例代碼)

    vue2.x中keep-alive源碼解析(實(shí)例代碼)

    Keep-Alive模式避免頻繁創(chuàng)建、銷(xiāo)毀鏈接,允許多個(gè)請(qǐng)求和響應(yīng)使用同一個(gè)HTTP鏈接,這篇文章主要介紹了vue2.x中keep-alive源碼解析,需要的朋友可以參考下
    2023-02-02

最新評(píng)論