Vue3中監聽 Ref 類型的數字數組

在 Vue 3 中,監聽一個?Ref?類型的數字數組(如?ref<number[]>([]))時,根據需求的不同,有幾種監聽方式:

1.?監聽整個數組的引用變化

當整個數組被重新賦值時觸發:

typescript

復制

下載

import { ref, watch } from 'vue';const numbers = ref<number[]>([1, 2, 3]);watch(numbers, (newVal, oldVal) => {console.log('數組被替換:', newVal, oldVal);
});

2.?監聽數組內部元素的變化(深度監聽)

當數組內部元素被修改(增/刪/改)時觸發:

typescript

復制

下載

watch(numbers, (newVal) => {console.log('數組內部變化:', newVal);
}, { deep: true }); // 關鍵:啟用深度監聽

3.?使用?watchEffect?自動跟蹤依賴

自動響應數組及其內部元素的變化:

typescript

復制

下載

import { watchEffect } from 'vue';watchEffect(() => {console.log('當前數組內容:', numbers.value);
});

4.?監聽特定索引的元素

只關注數組中某個索引位置的變化:

typescript

復制

下載

watch(() => numbers.value[0], // 監聽索引 0 的元素(newVal, oldVal) => {console.log('第一個元素變化:', newVal, oldVal);}
);

5.?監聽數組長度變化

只關注數組長度的變化:

typescript

復制

下載

watch(() => numbers.value.length,(newLen, oldLen) => {console.log(`數組長度變化: ${oldLen} -> ${newLen}`);}
);

完整示例代碼

vue

復制

下載

<script setup lang="ts">
import { ref, watch, watchEffect } from 'vue';const numbers = ref<number[]>([1, 2, 3]);// 1. 監聽整個數組引用
watch(numbers, (newVal, oldVal) => {console.log('數組引用變化:', { newVal, oldVal });
});// 2. 深度監聽內部元素
watch(numbers, (newVal) => {console.log('深度監聽內部變化:', newVal);
}, { deep: true });// 3. 自動跟蹤依賴
watchEffect(() => {console.log('watchEffect 觸發:', numbers.value);
});// 4. 監聽特定索引
watch(() => numbers.value[0],(newVal, oldVal) => {console.log('索引 0 變化:', { newVal, oldVal });}
);// 5. 監聽數組長度
watch(() => numbers.value.length,(newLen, oldLen) => {console.log('長度變化:', { newLen, oldLen });}
);// 測試方法
const changeArray = () => {numbers.value.push(4); // 觸發深度監聽、watchEffect、長度監聽
};const replaceArray = () => {numbers.value = [10, 20]; // 觸發引用監聽、深度監聽、watchEffect
};const updateElement = () => {numbers.value[0] = 100; // 觸發深度監聽、watchEffect、特定索引監聽
};
</script><template><div><p>數組內容: {{ numbers }}</p><button @click="changeArray">Push 新元素</button><button @click="replaceArray">替換整個數組</button><button @click="updateElement">修改第一個元素</button></div>
</template>

關鍵注意事項:

  1. 深度監聽?{ deep: true }
    必須顯式開啟才能檢測數組內部變化(如?pushsplice?或直接修改索引值)。

  2. 引用變化 vs 內部變化

    • 重新賦值整個數組(numbers.value = [...])會觸發引用變化

    • 修改數組內部元素(numbers.value[0] = 100?或?push())需要深度監聽

  3. watchEffect?的自動依賴
    在回調中使用到的響應式變量(如?numbers.value)會被自動跟蹤,無需聲明依賴。

根據你的具體場景選擇合適的監聽方式即可。

本文來自互聯網用戶投稿,該文觀點僅代表作者本人,不代表本站立場。本站僅提供信息存儲空間服務,不擁有所有權,不承擔相關法律責任。
如若轉載,請注明出處:http://www.pswp.cn/bicheng/85765.shtml
繁體地址,請注明出處:http://hk.pswp.cn/bicheng/85765.shtml
英文地址,請注明出處:http://en.pswp.cn/bicheng/85765.shtml

如若內容造成侵權/違法違規/事實不符,請聯系多彩編程網進行投訴反饋email:809451989@qq.com,一經查實,立即刪除!

相關文章

PoolThreadCache 類的結構和源碼實現

PoolThreadCache 在 Netty 的內存池中扮演著線程本地緩存的角色。它的主要目的是減少線程在分配內存時對全局 PoolArena 的競爭&#xff0c;通過緩存一部分最近釋放的內存塊&#xff0c;使得同一線程后續申請相同規格的內存時能夠快速獲取&#xff0c;從而提高分配效率。 下面…

Linux中的阻塞信號與信號原理

在Linux操作系統中&#xff0c;信號&#xff08;Signal&#xff09;是進程間通信和進程控制的核心機制之一。信號是一種異步通知機制&#xff0c;可以向進程發送異步事件通知&#xff0c;以便進程能夠處理系統級別的事件。本文將詳細探討Linux中的信號原理&#xff0c;重點講解…

QT學習教程(三十五)

事件處理&#xff08;- Event Processingn&#xff09; 事件是視窗系統或者Qt 本身在各種不同的情況下產生的。當用戶點擊或者釋放鼠標&#xff0c;鍵盤時&#xff0c;一個鼠標事件或者鍵盤事件就產生了。當窗口第一次顯示時&#xff0c;一個繪制事件會產生告訴新可見的窗口繪…

【Dify 案例】【MCP實戰】【三】【超級美食家】

接上次的超級助理,我們這一期給出一個超級美食家 首先:我的MCP要申請一個key ` 我們來看看這個MCP服務怎么使用呢。`https://modelscope.cn/mcp/servers/@worryzyy/howtocook-mcp插件里面需要配置 {"mcpServers":{"amap-amap-sse":{"url":&qu…

4.文件管理(文本、日志、Excel表)

目錄 1.文本 2.日志 3.Excel表 1.文本 using System.Text;namespace (自己創建的一個類) {/// <summary>/// 配置文件*.ini讀寫器。/// </summary>public class IniFile{[System.Runtime.InteropServices.DllImport("kernel32")]private static ex…

Java 包裝類詳解

什么是包裝類 Java包裝類&#xff08;Wrapper Classes&#xff09;是將8種基本數據類型封裝成對象的類&#xff0c;位于java.lang包中。每個基本數據類型都有對應的包裝類&#xff1a; byte → Byteshort → Shortint → Integerlong → Longfloat → Floatdouble → Doublec…

阿里云ACP認證-數據倉庫

數據倉庫 Kappa架構&#xff1a;將實時和離線代碼統一&#xff08;優化lambda架構&#xff09;&#xff0c;但是不好修正數據&#xff0c;開發周期長&#xff0c;成本浪費&#xff0c;對于歷史數據的高吞吐量力不從心 原一代數據倉庫&#xff1a; 離線&#xff1a;hivemaxcom…

WebRTC(五):TURN協議

TURN&#xff08;Traversal Using Relays around NAT&#xff09;協議是一個網絡協議&#xff0c;旨在解決 NAT&#xff08;網絡地址轉換&#xff09;和防火墻 環境下的 UDP/TCP通信問題。它通常與 STUN 和 ICE 協議一起使用&#xff0c;廣泛應用于 WebRTC、SIP 和視頻會議等實…

Python 的內置函數 hasattr

Python 內建函數列表 > Python 的內置函數 hasattr Python 的內置函數 hasattr() 用于檢查一個對象是否具有指定的屬性或方法。該函數的語法為&#xff1a; hasattr(object, name)參數說明&#xff1a; object&#xff1a;要檢查的對象&#xff0c;可以是任何 Python 對象…

docker使用技巧之把擴展卷命名變成有意義

背景 之前使用別人的鏡像之后&#xff0c;啟動docker后發出現了一堆看不懂名稱的擴展卷 eg&#xff1a;集群查看 擴展卷查看 這個時候如果有很多集群需要清理擴展卷就很麻煩&#xff0c;不知道是哪個集群的 操作步驟 可以實現的分析&#xff1a;這個擴展卷的信息應該是和…

《博物通書》《博物新編》與滿清歷史篡改

《博物新編》作為近代西方科技輸入中國的首部著作&#xff0c;其問世猶如一顆投入平靜湖面的巨石&#xff0c;在 19 世紀中期的中國激起層層漣漪&#xff0c;對中國近代科學發展產生了多維度、深層次的影響。它不僅是知識傳播的載體&#xff0c;更是推動中國科學從傳統走向近代…

【入門】【例18.1】 睡眠

| 時間限制&#xff1a;C/C 1000MS&#xff0c;其他語言 2000MS 內存限制&#xff1a;C/C 64MB&#xff0c;其他語言 128MB 難度&#xff1a;中等 分數&#xff1a;100 OI排行榜得分&#xff1a;12(0.1分數2難度) 出題人&#xff1a;root | 描述 一個人只有每天睡眠時間到達 8…

DAY 38 Dataset和Dataloader類

知識點回顧&#xff1a; Dataset類的__getitem__和__len__方法&#xff08;本質是python的特殊方法&#xff09;Dataloader類minist手寫數據集的了解 作業&#xff1a;了解下cifar數據集&#xff0c;嘗試獲取其中一張圖片 import torch import torch.nn as nn import torch.o…

【Kubernetes】以LOL的視角打開K8s

前言 對于大部分后端程序員乃至于非后端程序員來說&#xff0c;在當前的云原生時代&#xff0c;Kubernetes&#xff08;后稱K8s&#xff09;都是繞不開的一項技術&#xff1b;同時&#xff0c;對于這個時代的程序員來說&#xff0c;“英雄聯盟”&#xff08;后稱LOL&#xff0…

UE5 游戲模板 —— FirstShootGame

UE5 游戲模板 —— FirstShootGame 前言一、GameMode二、組件1.ShooterPickUpComponent單播多播 2.ShooterWeaponComponent附著武器開火 3.小結4.ShooterProjectile初始化碰撞受擊檢測 三、Character初始化輸入移動 總結 前言 有了前兩個俯視角游戲的基礎讓我們來看看相對復雜…

國家級與省級(不含港澳臺)標準地圖服務網站匯總

在先前的文章中&#xff0c;介紹了部分省級的標準地圖服務網站可以下載各個區縣近幾年、不同要素的標準地圖&#xff08;鏈接&#xff1a;國家與省市縣 標準地圖服務網站 審圖號地圖下載&#xff09;&#xff0c;但是當時只匯總了部分省級的標準地圖服務網站。 這兩天看到了一個…

前端開發面試題總結-vue3框架篇(一)

文章目錄 Vue3高頻問答一、vue2/vue3中常用的構建工具和腳手架分別是什么? 有什么區別?二、請說一說vue2和vue3的區別&#xff1f;三、請說一說vue2和vue3響應式原理的區別&#xff1f;四、vue3 如何定義響應式數據?五、說一說你對vue3中的setup函數?六、說一說vue3中的路由…

【LLM06---相對位置編碼】

文章目錄 相對位置編碼經典式XLNET式T5式DeBERTa式 相對位置編碼 上一節我們介紹了絕對位置編碼&#xff0c;這一節我們來看相對位置編碼&#xff0c;也就是用相對位置信息來表示&#xff0c;之前每一個token的位置式通過一個絕對的位置向量來表示的&#xff0c;現在我們在計算…

純跟蹤算法本質解密:航向角偏差=預瞄角?數學證明與工程實踐

定義關鍵問題 在深入純跟蹤算法核心前&#xff0c;必須澄清一對容易被混淆但至關重要的概念&#xff1a; 概念坐標系物理意義計算方式航向角偏差(α_global)全局坐標系車輛航向與預瞄點方向的夾角預瞄點方位角 - 車輛航向角預瞄角(α_body)車身坐標系預瞄點相對于車輛縱軸的夾…

自動駕駛叉車在倉庫環境中是否安全?

隨著自動駕駛叉車的興起&#xff0c;倉庫運營持續演進。叉車自動化技術的引入使倉庫設施變得更快、更安全且更具成本效益。然而一個關鍵問題依然存在&#xff1a;它們在繁忙的倉庫環境中是否安全&#xff1f; 一 、什么是自動駕駛叉車&#xff1f; 自動駕駛叉車&#xff0c;也…