vue3中的ref和reactive的區別

vue3中的ref和reactive的區別

    • 1、響應式數據
    • 2、ref
    • 3、reactive
    • 4、ref VS reactive
    • 5、往期回顧
      • 總結:

在這里插入圖片描述

1、響應式數據

處理響應式數據時到底是該用ref還是reactive...

響應式數據是指在 Vue.js 中,當數據發生變化時,相關的視圖會自動更新以反映這些變化的特性。Vue.js 的響應式系統通過數據綁定實現了數據和視圖之間的自動同步。具體來說,當你在 Vue 實例中聲明一個數據屬性時,Vue 將會將這些屬性轉換成響應式數據。這意味著當這些屬性的值發生變化時,相關的視圖會自動更新以反映這些變化。

舉例說明:

<template><div>數據a:{{ a }}</div><button @click="add">+1</button>
</template>
<script setup>
let a = 1;
const add = () => {a++;console.log(a);
};
</script>
<style lang="css" scoped></style>

數據a,點擊按鈕“+1”,數據a會增加1,并且會打印當前a的值,來看效果

點了n下+1,可是顯示的a的值并沒有改變,但是我們可以從打印的結果發現,我們的a實際上是改變了的。如果要讓我們的a變成一個響應式數據,也就是說a改變,展示在屏幕上的a也要變化,那么我們就要使用到 ref和reactive

2、ref

在 Vue 3 中,ref 是一個用于創建響應式引用的函數。它接受一個初始值作為參數,并返回一個包含響應式引用的對象。使用 ref 創建的值可以在模板中直接使用,并且當其值發生變化時,相關的 DOM 元素會自動更新。ref 通常用于創建可變的響應式值,例如基本類型數據,對象或數組。ref如何發揮作用的;

舉例說明ref處理基本數據類型

<template><div>數據a:{{ a }}</div><button @click="add">+1</button>
</template>
<script setup>
import { ref } from "vue";
let a = ref(1)
const add = () => {a.value++;console.log(a);
};
</script>
<style lang="css" scoped></style>

首先引入ref
在ref的括號中填入a的值
在修改a的值時,我們需要用.value來修改
來看看我們打印出來的a是什么

在使用ref以后,我們的a就變成了一個RefImpl的實例對象,我們可以看到a的值儲存在里面的.value屬性,于是通過.value我們就可以訪問到值,來看看效果:

這樣我們a的值就是一個響應式數據了

ref處理對象類型

同樣的,有一名叫大C的員工,點擊按鈕就可以給他漲工資

<template>員工信息<div>姓名:{{person.name}}</div><div>年齡:{{person.age}}</div><div>工資:{{person.salary}}</div><button @click="addSalary">漲工資</button>
</template><script setup>
import {ref} from 'vue'
let person = ref({name:'張三',age:18,salary:10000
})
const addSalary = ()=>{person.value.salary += 1000console.log(person.value);
}
</script>
<style lang="css" scoped>
</style>

看的出來,這也是一個響應式的數據,我們在處理基本數據類型修改的時候,我們都是用.value來獲取數據的,那么這里在修改salary的值的時候不應該是 person.value.salary.value嗎?我們來看person.value的打印結果…

我們可以看到,person.value是一個Proxy的實例對象,對象上有了我們的age等屬性,所以不需要再接上.value了

3、reactive

在 Vue 3 中,reactive 是一個函數,用于將普通 JavaScript 對象轉換為響應式對象。響應式對象的屬性在被訪問和修改時會自動觸發視圖的更新,reactive 可以用于創建包含復雜數據結構的響應式對象,如嵌套對象和數組。

reactive是不能用來處理基本數據類型的,reactive處理基本數據類型來看例子:

<template><div>a:{{a}}</div></template><script setup>import {reactive} from 'vue'const a = reactive(1)</script>

這時我們雖然能夠看到a顯示,但是會報警告:

reactive處理對象數據類型

<template>員工信息<div>姓名:{{person.name}}</div><div>年齡:{{person.age}}</div><div>工資:{{person.salary}}</div><button @click="addSalary">漲工資</button></template><script setup>import {reactive} from 'vue'let person = reactive({name:'張三',age:18,salary:10000})const addSalary = ()=>{person.salary += 1000console.log(person);}</script><style lang="css" scoped></style>

先來看看person是什么…

person是Proxy的一個實例對象,到這里你就應該明白怎么訪問他的值了…
并且,在上面ref處理對象類型的時候,.value也是一個Proxy的實例對象,到這里,突然意識到原來ref處理對象數據類型的時候會偷偷求助reactive…

4、ref VS reactive

1、返回值類型:

  • ref 返回一個包含響應式基本數據類型值的對象。
  • reactive 返回一個包含響應式對象的 Proxy 對象。
    包裝的數據類型:
  • ref 可以包裝基本數據類型(如數字、字符串、布爾值等)和引用類型(如對象、數組等)。
  • reactive 只能包裝引用類型數據(對象、數組等)。
    訪問數據:
  • 通過 ref 創建的響應式對象,需要通過 .value 訪問或修改其值。
  • 通過 reactive 創建的響應式對象,可以直接訪問和修改其屬性。
    應用場景:
  • ref 適用于包裝單個基本數據類型或對象。
  • reactive 適用于包裝包含多個屬性或復雜數據結構的對象。

其實不管是用ref還是 reactive,就像是在情人節選擇禮物一樣,有時候你需要一束精致的玫瑰(ref),有時候你更想要一份充滿驚喜的禮物(reactive)。無論你選擇哪個,都是為了讓代碼更加美好,讓開發更加愉快!


5、往期回顧


vue3 + TS + vite 搭建中后臺管理系統(完整項目)
vue3 + JS + vant 搭建移動端H5項目(完整項目)
手把手教 Vue3.2+Vite+Echarts 5 繪制3D線條效果中國地圖



總結:

前端路上 | 所知甚少,唯善學。
各位小伙伴有什么疑問,歡迎留言探討。

— 關注我:前端路上不迷路 —




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

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

相關文章

【bash】2、手把手實現一個 bash shell:多個機器批量執行 shell 命令,支持 ip 補全

文章目錄 一、需求&#xff1a;多臺機器批量遠程執行 shell 命令1.1 業務需求拆解為腳本需求1.2 幫助函數&#xff1a;使用說明文檔1.3 main 函數框架 二、功能&#xff1a;單機 sshp 執行2.1 fullip 函數&#xff1a;實現 ip 補全2.1.1 參數說明2.1.2 定義全局變量2.1.3 實現&…

Cu-HCP-H035 Cu-HCP-R250銅合金高精度零部件

Cu-HCP-H035 Cu-HCP-R250銅合金高精度零部件 CDA102-3/4H EN1982-CC333G EN1982-CC492K BS1400-LG4 EN1982-CC491K BS1400-LG2 CuNi18Zn19Pb1/CW408J CuNi12Zn38Mn5Pb2/CW407J CuNi12Zn30Pb1/CW406J CuNi12Zn29/CW405J CuNi12Zn25Pb1/CW404J CuNi10Zn42Pb2/CW402J CuNi10Zn27/C…

Pytorch 復習總結 4

Pytorch 復習總結&#xff0c;僅供筆者使用&#xff0c;參考教材&#xff1a; 《動手學深度學習》Stanford University: Practical Machine Learning 本文主要內容為&#xff1a;Pytorch 深度學習計算。 本文先介紹了深度學習中自定義層和塊的方法&#xff0c;然后介紹了一些…

基于Beego 1.12.3的簡單website實現

參考 用Beego開發web應用 https://www.cnblogs.com/zhangweizhong/p/10919672.htmlBeego官網 Homepage - beego: simple & powerful Go app frameworkbuild-web-application-with-golang https://github.com/astaxie/build-web-application-with-golang/blob/master/zh/pr…

源碼的角度分析Vue2數據雙向綁定原理

什么是雙向綁定 我們先從單向綁定切入&#xff0c;其實單向綁定非常簡單&#xff0c;就是把Model綁定到View&#xff0c;當我們用JavaScript代碼更新Model時&#xff0c;View就會自動更新。那么雙向綁定就可以從此聯想到&#xff0c;即在單向綁定的基礎上&#xff0c;用戶更新…

微信開發者工具-代碼管理和碼云Github遠程倉庫集成

目錄 思考&#xff1a;IDE如何進行代碼管理 代碼管理方式 一、自身提供服務 二、Git 擴展 1、環境準備 2、創建項目代碼 3、進行項目Git初始化 4、在碼云新建遠程倉庫 5、將項目進行遠程倉庫關聯 三、SVN擴展 四、代碼管理 思考&#xff1a;IDE如何進行代碼管理 初識開…

服務器部署測試環境回顧與改進建議

任務概述&#xff1a; 原計劃在2小時內完成的任務&#xff0c;由于遇到一系列挑戰&#xff0c;最終耗時1.5天。任務目標是在無外網環境的服務器上建立測試環境&#xff0c;涉及將SSD硬盤數據遷移至服務器、SSH連接、運行測試程序并監控服務器功耗。 高效實施策略&#xff1a;…

fs讀取目錄、文件

fs讀取文件 process.cwd() 是 Node.js 中的一個方法&#xff0c;它返回 Node.js 進程的當前工作目錄。這個工作目錄通常是啟動 Node.js 進程時所在的目錄。 const fs require(fs); const path require(path);// 讀取指定目錄 const configPath path.join(process.cwd(), c…

StarRocks實戰——貝殼找房數倉實踐

目錄 前言 一、StarRocks在貝殼的應用現狀 1.1 歷史的數據分析架構 1.2 OLAP選型 1.2.1 離線場景 1.2.2 實時場景 1.2.3 StarRocks 的引入 二、StarRocks 在貝殼的分析實踐 2.1 指標分析 2.2 實時業務 2.3 可視化分析 三、未來規劃 3.1 StarRocks集群的穩定性 3…

PMP考試培訓費用多少錢?

PMP考試的相關費用包括報名費用、培訓費用和證書續證費用三個部分。 一、PMP考試報名費用&#xff1a; 首次報考費用為3900元&#xff0c;如果未通過考試可以在英文報名有效期內進行補考報名&#xff0c;補考費用為2500元。 付費方式是在項目管理學會官方網站上提交報考資料…

企業數字化轉型的第一步:由被動多云向主動多云轉變

隨著經濟環境、市場形勢、技術發展、用戶需求等諸多因素的變化&#xff0c;數字化轉型為企業進一步提升效率和競爭力、提供更加豐富的個性化產品和服務、進行業務場景創新、探尋新的增長機會和運營模式提供了嶄新的途徑。越來越多的企業意識到&#xff0c;數字化轉型已不是企業…

第1篇 Linux Docker安裝rabbitmq

Docker安裝RabbitMq 1、搜索rabbitmq鏡像 docker search rabbitmq2、下載rabbitmq鏡像 docker pull rabbitmq3、運行rabbitmq服務 docker run -d --name rabbitmq --restart always -p 15672:15672 -p 5672:5672 rabbitmq4、訪問rabbitmq http://192.168.1.x:15672 5、rab…

亞信安慧AntDB:打破數據孤島,實現實時處理

AntDB數據庫以其獨特的創新能力在分布式數據庫領域引領潮流。其中&#xff0c;融合統一與實時處理是其兩大核心創新能力&#xff0c;為其贏得廣泛關注與贊譽。融合統一意味著AntDB能夠將多種不同類型的數據庫融合為一體&#xff0c;實現數據的統一管理與處理&#xff0c;極大地…

電視盒子什么品牌好?資深數碼粉強推口碑電視盒子推薦

我對各類數碼產品是非常熟悉的&#xff0c;尤其是電視盒子&#xff0c;用過超十五款了&#xff0c;涵蓋了各個主流品牌&#xff0c;最近看到很多朋友在討論不知道電視盒子什么品牌好&#xff0c;我這次要來分享的就是口碑最好的五款電視盒子推薦給各位不懂如何選電視盒子的新手…

AI、AIGC、AGI、ChatGPT它們的區別?

今天咱們聊點熱門話題&#xff0c;來點科普時間——AI、AIGC、AGI和ChatGPT到底是啥&#xff1f;這幾個詞聽起來好像挺神秘的&#xff0c;但其實它們就在我們生活中。讓我們一起探索這些術語的奧秘&#xff01; AI&#xff08;人工智能&#xff09;&#xff1a;先說說AI&#…

數倉技術選型特點

高性能&#xff1a;用全并行的MPP架構數據庫&#xff0c;業務數據被分散存儲在多個節點上&#xff0c;數據分析任務被推送到數據所在位置就近執行&#xff0c;并行地完成大規模的數據處理工作&#xff0c;實現對數據處理的快速響應。 易擴展&#xff1a;Shared-Nothing開放架構…

電梯物聯網之梯控相機方案-防止電瓶車進電梯

梯控現狀 隨著電梯產品在智能化建筑的日益普及,對于電梯的智能化管理 安全性需求 的要求越來越迫切。尤其今年來隨著電瓶車的大量普及&#xff0c;發起多起樓道、轎廂電瓶車著火惡性事件&#xff0c; 造成了極大的社會 負面影響。控制電瓶車進入單元門&#xff0c;樓道以及電梯…

Vue官網“食用指南”

把Vue官網當做一個工具來用&#xff0c;有問題&#xff0c;先來官網查一查。 官網中常用的板塊 官網&#xff1a;https://cn.vuejs.org/上手后&#xff0c;最常用的模塊是【快速上手】【API】。所以務必要知道這兩個模塊在哪里&#xff0c;怎么使用。![image.png](https://img…

/proc/cpuinfo文件內容詳解

/proc/cpuinfo 文件包含了有關系統 CPU 的信息&#xff0c;每一行代表一個屬性及其對應的值。以下是一些常見的屬性及其含義&#xff1a; 1. processor&#xff1a;表示 CPU 的物理編號&#xff0c;通常從 0 開始遞增。 2. vendor_id&#xff1a;CPU 廠商的名稱&#xff0c;如…

藍橋杯 砝碼稱重 dp/dfs

題目鏈接&#xff1a; https://www.lanqiao.cn/problems/1447/learning/?subject_code1&group_code4&match_num12&match_flow1&origincup 思想&#xff1a;dfs暴力枚舉過一半的分 代碼&#xff1a; #include<bits/stdc.h> using namespace std;#def…