Vue3學習——computed、watch、watchEffect

computed

  • 與Vue2.x中computed配置功能一致
  • 寫法
import {computed} from 'vue'setup(){...//計算屬性——簡寫let fullName = computed(()=>{return person.firstName + '-' + person.lastName})//計算屬性——完整let fullName = computed({get()return person.firstName + '-' + person.lastName},set(value){const nameArr = value.split('-')person.firstName = nameArr[0]person.lastName = nameArr[1]}})
}

watch

  • 注意
    • 監視reactive定義的響應式數據時:oldValue無法正確獲取、強制開啟了深度監視(deep配置失效)。
    • 監視reactive定義的響應式數據中的某個屬性時:deep配置有效。
情況一:監視ref定義的響應式數據
  • 監視ref定義的對象,改變某一個屬性時,newValue和oldValue是同一個值;
  • 若改變整個對象newValue和oldValue不一樣;
	 watch(sum, (newValue, oldValue) => {console.log('sum變化了', newValue, oldValue)}, {immediate: true})

情況二:監視多個ref定義的響應式數據(寫成數組格式)

	watch([sum, msg], (newValue, oldValue) => {console.log('sum或msg變化了', newValue, oldValue)})

情況三:監視reactive定義的響應式數據,deep默認開啟,且關不掉

	 watch(person, (newValue, oldValue) => {console.log('person變化了', newValue, oldValue)}, {immediate: true, deep: false}) //此處的deep配置不再奏效

情況四:監視reactive定義的響應式數據中某個屬性

  • 可以監視整體改變,也可以監視某個屬性改變
  • 監視的屬性不是【對象類型】,需寫成函數
  • 監視的屬性是【對象類型】,可直接編,也可使用函數,推薦使用函數并添加deep屬性
    (因為直接寫person,無法監聽到整個對象的改變;deep是為了深層監聽)
    watch(() => person.job, (newValue, oldValue) => {console.log('person的job變化了', newValue, oldValue)}, {immediate: true, deep: true})

情況五:監視reactive定義的響應式數據中某些屬性

    watch([() => person.job, () => person.name], (newValue, oldValue) => {console.log('person的job變化了', newValue, oldValue)}, {immediate: true, deep: true})

特殊情況

    watch(() => person.job, (newValue, oldValue) => {console.log('person的job變化了', newValue, oldValue)}, {deep: true}) //此處由于監視的是reactive素定義的對象中的某個屬性,所以deep配置有效

停止監視

    const stopWatch =  watch(sum, (newValue, oldValue) => {console.log('sum變化了', newValue, oldValue)if (sum > 10) {stopWatch() // 停止監視}})

watchEffect

  • watch的套路:既要指明監視的屬性,也要指明監視的回調。

  • watchEffect的套路:不用指明監視的哪個屬性,監視的回調中用到哪個屬性,那就監視哪個屬性。

  • watchEffect有點像computed:

  • 但computed注重的計算出來的值(回調函數的返回值),所以必須要寫返回值。而watchEffect更注重的是過程(回調函數的函數體),所以不用寫返回值。


// watchEffect所指定的回調中用到的數據只要發生變化,則直接重新執行回調。初始化也會執行一次watchEffect(()=>{const x1 = sum.valueconst x2 = person.ageconsole.log('watchEffect配置的回調執行了')
})

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

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

相關文章

算法——模擬

1. 什么是模擬算法? 官方一點來說 模擬算法(Simulation Algorithm)是一種通過模擬現實或抽象系統的運行過程來研究、分析或解決問題的方法。它通常涉及創建一個模型,模擬系統中的各種事件和過程,以便觀察系統的行為&a…

Redis緩存一致性問題(自用記錄)

背景 在開發過程中,redis緩存技術被大范圍應用。由于現在的系統大多是分布式的,高并發的,redis和傳統的數據庫,存在數據不一致的問題。 解決方案 本文主要探討兩者數據不一致的解決方案: 給緩存設置過期時間&#x…

dell戴爾電腦靈越系列Inspiron 15 3520原廠Win11系統中文版/英文版

Dell戴爾筆記本靈越3520原裝出廠Windows11系統包,恢復出廠開箱預裝OEM系統 鏈接:https://pan.baidu.com/s/1mMOAnvXz5NCDO_KImHR5gQ?pwd3nvw 提取碼:3nvw 原廠系統自帶所有驅動、出廠主題壁紙、系統屬性聯機支持標志、Office辦公軟件、MyD…

Jmeter接口測試 ,這應該是全網最詳細的教程了

🍅 視頻學習:文末有免費的配套視頻可觀看 🍅 關注公眾號【互聯網雜貨鋪】,回復 1 ,免費獲取軟件測試全套資料,資料在手,漲薪更快 一、Jmeter 的使用步驟 打開Jmeter 安裝包,進入\bi…

postman-使用Postman的模擬服務來模擬(mock)后端數據,完成前端模擬API調用

最近項目上比較忙,任務多時間緊,導致后端開發任務繁多,無法及時開發完畢,但是前端同學已經把對應功能開發完成,需要進行前后端聯調來驗證API及一些交互問題;這不能因為后端的進度來影響前端的工作完成情況&…

【Linux進程】馮·諾依曼體系結構以及操作系統的深入理解

📙 作者簡介 :RO-BERRY 📗 學習方向:致力于C、C、數據結構、TCP/IP、數據庫等等一系列知識 📒 日后方向 : 偏向于CPP開發以及大數據方向,歡迎各位關注,謝謝各位的支持 目錄 1.馮諾依曼體系結構特…

kafka和ZK的關系

zk相當于是kafka的一個基礎設施 Kafka是一種高吞吐量、可擴展的分布式發布訂閱消息系統,ZooKeeper是一個分布式協調服務,用于管理和協調分布式系統中的各種資源 Zookeeper:管理broker,consumer 創建broker后,向zk注冊…

適用于生物行業的樣本管理系統

在生物樣本管理系統的應用中,我們首先需要了解生物樣本的特點和要求。生物樣本具有多樣性和易變性,需要被妥善保存和跟蹤,以確保其質量和可用性。 因此,一個有效的生物樣本管理系統需要具備以下特點: 全面性&#xff1…

Spring Event的原理以及缺陷

原理:Spring 事件監聽機制及原理分析 - Admol - 博客園 (cnblogs.com) 使用bug:Spring Event 別瞎用!從我司的悲劇中,我總結了6 條最佳實踐!-騰訊云開發者社區-騰訊云 (tencent.com)

2024最新任推邦邀請碼是什么

任推邦是一款非常受歡迎的推廣APP,任推邦邀請碼是【222222】獲得現金獎勵和提成獎勵用戶可以通過邀請好友加入來獲取收益。2024最新的任推邦邀請碼是【222222】,小編已經給大家整理好了他趣許多的邀請碼,想要領取獎勵的小伙伴快來和小編一起了…

聚合函數()不要隨意加空格

報錯:1630 - FUNCTION link.SUM does not exist. Check the Function Name Parsing and Resolution section in the Reference Manual 解決方法:count、avg、sum等函數后緊隨的()之間不能加空格,去掉這個空格即可,因為count()、a…

js 監聽元素是否出現在可視區域--IntersectionObserver

觀察者模式監聽判斷dom元素是否在可視區域內 本項目是使用vue3的寫法。 1.IntersectionObserver IntersectionObserver可以用來自動監聽元素是否進入了設備的可視區域之內,而不需要頻繁的計算來做這個判斷。由于可見(visible)的本質是&…

融中穿刺路徑角度評估的C++技術實現

消融模型的三維渲染 我們以肝部為例,通常肝部在做消融手術規劃時有幾個步驟。 一三維重建: 對器官進行圖像分割; 對腫瘤的原發區域GTV進行勾畫。 二穿刺路徑的規劃: 路徑規劃當中有幾個約束:穿刺深度、危及器官的…

OpenAI推出首個AI視頻模型Sora:重塑視頻創作與體驗

鏈接:華為OD機考原題附代碼 Sora - 探索AI視頻模型的無限可能 隨著人工智能技術的飛速發展,AI視頻模型已成為科技領域的新熱點。而在這個浪潮中,OpenAI推出的首個AI視頻模型Sora,以其卓越的性能和前瞻性的技術,引領著…

SpringBoot快速整合Thymeleaf實現文件上傳案例

SpringBoot快速整合Thymeleaf實現文件上傳案例 文章目錄 SpringBoot快速整合Thymeleaf實現文件上傳案例1. 創建工程2. pom.xml文件2. application.yml 配置3. 前端fileupload.html4. 后端Controller 本案例環境: SpringBoot: 2.3.0.RELEASEJDK: 1.8前端模板: thymel…

【PHP進階】Redis批處理緩存

大家好,我是程序員若風,又到了技術分享時刻。 概要 在某些場景下,我們需要頻繁的使用到緩存,比如需要獲取多個key值,如果采用單個拿緩存的辦法,會造成網絡IO極大的浪費,所以我們需要用戶Redis…

Leetcode3036. 匹配模式數組的子數組數目 II

Every day a Leetcode 題目來源:3036. 匹配模式數組的子數組數目 II 解法1:KMP 設數組 nums 的長度為 m,數組 pattern 的長度為 n。 遍歷數組 nums 的每個長度是 n1 的子數組并計算子數組的模式,然后與數組 pattern 比較&…

JavaScript 設計模式之觀察者模式

觀察者模式 觀察者模式又被稱為發布-訂閱模式,使用一個對象來收集訂閱者,在發布時遍歷所有訂閱者,然后將信息傳遞給訂閱者,可以這樣來實現一個簡單的模式 const Observable (function () {let __messages {}return {register:…

win系統下安裝mysql5.7并配置環境變量、設置root用戶和服務啟動的詳細操作教程

本篇文章主要講解:win系統下安裝mysql5.7并配置環境變量、設置root用戶和服務啟動的詳細操作教程 日期:2024年2月22日 作者:任聰聰 一、mysql5.7版本的下載 官方下載地址:https://downloads.mysql.com/archives/community/ 步驟…

服務器生信環境配置腳本

服務器生信環境配置腳本的重要性在于它為生物信息學的數據分析提供了一個統一和標準化的計算環境。通過自動化的配置腳本,可以快速地在服務器上部署和設置生物信息學的軟件和依賴庫,確保分析的可重復性和準確性。這樣,生物信息學家和研究人員…