亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

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

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

使用reactive包裹數(shù)組正確賦值

需求:將接口請求到的列表數(shù)據(jù)賦值給響應(yīng)數(shù)據(jù)arr

const arr = reactive([]);
 
const load = () => {
  const res = [2, 3, 4, 5]; //假設(shè)請求接口返回的數(shù)據(jù)
  // 方法1 失敗,直接賦值丟失了響應(yīng)性
  // arr = res;
  // 方法2 這樣也是失敗
  // arr.concat(res);
  // 方法3 可以,但是很麻煩
  res.forEach(e => {
    arr.push(e);
  });
};

vue3使用proxy,對于對象和數(shù)組都不能直接整個賦值。

使用方法1能理解,直接賦值給用reactive包裹的對象也不能這么做。

方法2為什么不行?

只有push或者根據(jù)索引遍歷賦值才可以保留reactive數(shù)組的響應(yīng)性?

如何方便的將整個數(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重新賦值無效

vue3官方的文檔說明

reactive() 返回一個對象的響應(yīng)式代理

所以 reactive 方法應(yīng)該作用于一個對象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() {
? ? // 需要一個帶默認(rèn)值的數(shù)組list;
? ?? ?let list = reactive([{id: 1, name: 'Andy'}])
? ??
? ? // 每次觸發(fā)事件重置list,把新值放入,此種方式不會觸發(fā)視圖更新
? ? const checkBtn = () => {
? ? ? // 此時重置操作 地址指向變成一個新的地址,不會觸發(fā)視圖更新
? ? ? list = [{id: 1, name: 'Andy'}]
? ? ? list.push({id: 2, name: 'Lucy'})
? ? }
? ??
? ? // --------------------------------------------------
? ? // 正確的重置處理方法如下:使用reactive將數(shù)組包裹到一個對象中
? ? 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é)

以上為個人經(jīng)驗,希望能給大家一個參考,也希望大家多多支持腳本之家。

相關(guān)文章

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

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

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

    Vue實現(xiàn)簡易計算器

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

    vue@cli3項目模板怎么使用public目錄下的靜態(tài)文件

    這篇文章主要介紹了vue@cli3項目模板怎么使用public目錄下的靜態(tài)文件,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2020-07-07
  • Vue子組件如何修改父組件數(shù)據(jù)的方法及注意事項

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

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

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

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

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

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

    Vue2.0表單校驗組件vee-validate的使用詳解

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

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

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

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

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

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

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

最新評論