vue3 watch和watchEffect 的用法和區別

在 Vue 3 里,watchwatchEffect 都是用于響應式數據變化的 API,但它們在使用方法和應用場景上存在差異。下面詳細介紹它們的用法和區別。

用法

watch

watch 用于監聽特定的響應式數據源,當數據源發生變化時,會執行相應的回調函數。它可以監聽單個數據源,也能監聽多個數據源。

監聽單個數據源

import { ref, watch } from 'vue';const count = ref(0);watch(count, (newValue, oldValue) => {console.log(`count 從 ${oldValue} 變為 ${newValue}`);
});count.value = 1;

在這個例子中,watch 監聽 count 的變化,當 count 的值改變時,回調函數會被觸發,打印出新舊值。

監聽多個數據源

import { ref, watch } from 'vue';const count1 = ref(0);
const count2 = ref(0);watch([count1, count2], ([newCount1, newCount2], [oldCount1, oldCount2]) => {console.log(`count1 從 ${oldCount1} 變為 ${newCount1},count2 從 ${oldCount2} 變為 ${newCount2}`);
});count1.value = 1;

這里 watch 監聽 count1count2 的變化,當其中任何一個值改變時,回調函數就會被觸發。

watchEffect

watchEffect 會立即執行傳入的函數,并自動追蹤函數內部依賴的所有響應式數據。當這些依賴的數據發生變化時,函數會再次執行。

import { ref, watchEffect } from 'vue';let props = defineProps(['orderid','randomid'])
const count = ref(0);watchEffect(() => {//此函數內監聽的任何值有變化都會觸發此函數的執行,要想每次都執行可以外部引入隨機數console.log('watchEffect',props.orderid,props.randomid)  //通過引入生成的隨機數randomid,即使orderid沒有變化,此函數也會執行一遍,實現實時刷新console.log(`count 的值是 ${count.value}`);});count.value = 1;

在這個例子中,watchEffect 會立即執行回調函數,打印出 count 的初始值。當 count 的值改變時,回調函數會再次執行,打印出新的值。通過引入生成的隨機數randomid,即使orderid,count 沒有變化,此函數也會執行一遍,實現實時刷新

區別

1. 觸發時機
  • watch:默認情況下,只有當監聽的數據源發生變化時,回調函數才會執行。它不會在組件初始化時立即執行回調函數,除非設置了 immediate: true 選項。
  • watchEffect:會立即執行傳入的函數,并且在依賴的響應式數據發生變化時再次執行。
2. 依賴追蹤
  • watch:需要明確指定要監聽的數據源,它只會監聽這些明確指定的數據源的變化。
  • watchEffect:會自動追蹤函數內部依賴的所有響應式數據,無需手動指定。這使得代碼更加簡潔,但也可能導致意外的重新執行,因為任何被函數訪問的響應式數據的變化都會觸發函數的重新執行。
3. 舊值獲取
  • watch:回調函數可以接收兩個參數,分別是新值和舊值,方便對比數據的變化。
  • watchEffect:無法直接獲取舊值,因為它沒有明確的新舊值對比機制。
4. 應用場景
  • watch:適用于需要在數據變化時執行特定操作,并且需要對比新舊值的場景,比如在數據變化時發送網絡請求、更新其他數據等。
  • watchEffect:適用于需要在響應式數據變化時自動更新副作用的場景,比如在數據變化時更新 DOM、計算派生數據等,不需要明確指定依賴的情況。

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

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

相關文章

Qt中修改了UI設計文件后編譯不生效問題的解決辦法

復制工程過來后: 1、刪除build文件 2、刪除.user文件,恢復為文件最初的那樣 3、執行make distclean,刪除所有由先前構建過程生成的文件 4、再次打開工程,修改ui文件編譯生效!

EtherCAT轉ProfiNet邊緣計算網關配置優化:汽車制造場景下PLC與機器人協同作業案例

1.行業背景與需求分析 智能汽車焊裝車間是汽車制造的核心工藝環節,某德國豪華品牌在其上海MEB工廠新建的焊裝車間中,采用西門子S7-1500PLC作為ProfiNet主站,負責整線協調與質量追溯;同時部署KUKAKR1500Titan機器人(Eth…

day46—雙指針-兩數之和-輸入有序數組(LeetCode-167)

題目描述 給你一個下標從 1 開始的整數數組 numbers &#xff0c;該數組已按 非遞減順序排列 &#xff0c;請你從數組中找出滿足相加之和等于目標數 target 的兩個數。如果設這兩個數分別是 numbers[index1] 和 numbers[index2] &#xff0c;則 1 < index1 < index2 &l…

線性代數 | 知識點整理 Ref 1

注&#xff1a;本文為 “線性代數 | 知識點整理” 相關文章合輯。 因 csdn 篇幅合并超限分篇連載&#xff0c;本篇為 Ref 1。 略作重排&#xff0c;未整理去重。 圖片清晰度限于引文原狀。 如有內容異常&#xff0c;請看原文。 線性代數知識匯總 Arrow 于 2016-11-27 16:27:5…

比特幣的跨輸入簽名聚合(Cross-Input Signature Aggregation,CISA)

1. 引言 2024 年&#xff0c;人權基金會&#xff08;Human Rights Foundation&#xff0c;簡稱 HRF&#xff09;啟動了一項研究獎學金計劃&#xff0c;旨在探討“跨輸入簽名聚合”&#xff08;Cross-Input Signature Aggregation&#xff0c;簡稱 CISA&#xff09;的潛在影響。…

3.基礎開發工具

1.軟件包管理器 1.1什么是軟件包 ? 在Linux下安裝軟件, ?個通常的辦法是下載到程序的源代碼, 并進?編譯, 得到可執?程序. ? 但是這樣太?煩了, 于是有些?把?些常?的軟件提前編譯好, 做成軟件包(可以理解成windows上 的安裝程序)放在?個服務器上, 通過包管理器可以很…

Golang errors 包快速上手

文章目錄 1.變量2.類型3.函數3.1 New3.2 Is簡介函數簽名核心功能示例代碼使用場景注意事項小結 3.3 As簡介函數簽名核心功能示例代碼使用場景注意事項小結 3.4 Unwrap簡介函數簽名核心功能使用示例使用場景注意事項小結 3.5 Join簡介函數簽名核心功能使用場景注意事項小結 4.小…

Java File 類詳解

Java File 類詳解 File 類是 Java 中用于表示文件和目錄路徑名的抽象類&#xff0c;位于 java.io 包中。它提供了豐富的 API&#xff0c;用于操作文件系統&#xff0c;包括創建、刪除、重命名、查詢文件屬性等功能。 1. File 類核心知識點 &#xff08;1&#xff09;構造方法…

基于javaweb的SpringBoot兒童愛心管理系統設計與實現(源碼+文檔+部署講解)

技術范圍&#xff1a;SpringBoot、Vue、SSM、HLMT、Jsp、PHP、Nodejs、Python、爬蟲、數據可視化、小程序、安卓app、大數據、物聯網、機器學習等設計與開發。 主要內容&#xff1a;免費功能設計、開題報告、任務書、中期檢查PPT、系統功能實現、代碼編寫、論文編寫和輔導、論文…

Unity Nav Mesh導航系統的簡單使用

標題 1.下載。2.面板位置3.object面板4.Area面板5.Bake面板6.Agent面板7.Nav Mesh Agent組件8.Nav Mesh Obstacle組件9.簡單使用 1.下載。 unity2022以上版本要去packageManager中下載。 2.面板位置 3.object面板 Navigation Static&#xff1a;設置該物體是否被列入靜態尋路…

FairyGUI圖標文字合批失敗的原因

1&#xff09;FairyGUI圖標文字合批失敗的原因 2&#xff09;為什么Cubemap的內存占用超高 3&#xff09;如何找到網格某個切面的中心點 4&#xff09;為什么SafeZone在倒屏后方向相反 這是第428篇UWA技術知識分享的推送&#xff0c;精選了UWA社區的熱門話題&#xff0c;涵蓋了…

[BUG]Cursor C++擴展不支持

本文內容組織形式 問題描述失效原因解決方案使用野版C Extension 猜你喜歡結語 問題描述 日期&#xff1a;20250419 操作系統&#xff1a; mac C代碼沒有辦法進行跳轉&#xff0c;并且和以前的文本標亮也不同 并且還有如下問題彈窗 C/C 擴展只能與 Microsoft Visual Studio…

深?理解 JVM 執?引擎

深?理解 JVM 執?引擎 其中前端編譯是在 JVM 虛擬機之外執?&#xff0c;所以與 JVM 虛擬機沒有太?的關系。任何編程語?&#xff0c;只要能夠編譯出 滿? JVM 規范的 Class ?件&#xff0c;就可以提交到 JVM 虛擬機執?。?于編譯的過程&#xff0c;如果你不是想要專?去研…

Ubuntu 部署 DeepSeek

在 Ubuntu 系統上部署 DeepSeek 模型&#xff0c;能讓用戶利用其強大的人工智能能力&#xff0c;同時保障數據的安全性與操作的自主性。不過&#xff0c;這一過程涉及諸多技術細節&#xff0c;需要謹慎操作。以下將為你詳細介紹在 Ubuntu 系統部署 DeepSeek 的操作步驟及注意事…

通義靈碼 Rules 庫合集來了,覆蓋Java、TypeScript、Python、Go、JavaScript 等

通義靈碼新上的外掛 Project Rules 獲得了開發者的一致好評&#xff1a;最小成本適配我的開發風格、相當把團隊經驗沉淀下來&#xff0c;是個很好功能…… 那么有哪些現成的 Rules 可以抄作業呢&#xff0c;今天我們官方輸出了 Java、TypeScript、Python、Go、JavaScript 等語…

山東大學軟件學院項目實訓-基于大模型的模擬面試系統-Token過期重定向問題

項目結構 ├── assets/ # 靜態資源&#xff08;CSS/圖片&#xff09; ├── components/ # Vue 組件 ├── layouts/ # 布局模板 ├── pages/ # 自動生成路由 ├── plugins/ # 插件&#xff08;如 axios 攔截器&#xff09; …

SAP案例:珠海漢勝科技SAP S/4 HANA智能制造實踐與價值實現

客戶簡介 珠海漢勝科技股份有限公司為高科技生產企業&#xff0c;成立于1985年&#xff0c;擁有員工近2000人。主要從事生產、銷售、研發&#xff1a;光纖光纜、電線、電纜及附件、鋁塑復合管&#xff1b;光纖光纜、電纜、電線生產項目的策劃及技術咨詢。它致力于為國內外無線電…

Spring Boot 項目中發布流式接口支持實時數據向客戶端推送

1、pom依賴添加 <dependency><groupId>org.springframework.boot</groupId><artifactId>spring-boot-starter-webflux</artifactId></dependency>2、事例代碼 package com.pojo.prj.controller;import com.pojo.common.core.utils.String…

Zookeeper 可觀測性最佳實踐

Zookeeper 介紹 ZooKeeper 是一個開源的分布式協調服務&#xff0c;用于管理和協調分布式系統中的節點。它提供了一種高效、可靠的方式來解決分布式系統中的常見問題&#xff0c;如數據同步、配置管理、命名服務和集群管理等。本文介紹通過 DataKit 采集 Zookeeper 指標&#…

【安全】DVWA靶場滲透

【安全】DVWA靶場滲透 備注一、環境搭建二、弱口令&#xff08;Brute Force&#xff09;三、命令注入&#xff08;Command Injection&#xff09;四、CSRF&#xff08;Cross Site Request Forgery&#xff09;五、文件包含&#xff08;File Inclusion&#xff09;六、文件上傳&…