淺談vue3中ref、toRef、toRefs?和?reactive的區(qū)別
一、ref——定義任意類型響應(yīng)式數(shù)據(jù)
- ref 能定義“任何類型”的響應(yīng)式數(shù)據(jù)(ref 在 vue3 中指響應(yīng)式數(shù)據(jù))。
- 參數(shù)可以傳入任意數(shù)據(jù)類型。
- 使用 ref 定義的屬性必須通過 .value 的形式才能修改其值。屬性的值一旦被修改就會觸發(fā)模板的重新渲染以顯示最新的值。
- 對于在 setup 返回的 refs(return 出的對象里的屬性),因?yàn)樵谀0逯性L問它們時(shí),它們會被自動淺解包,所以在 template 中使用時(shí)無需加 .value。
1、對于在 setup 中手動返回的響應(yīng)式數(shù)據(jù),在 template 中使用時(shí)無需加 .value
例如:
<template>
? <div>{{ count }}</div>
</template>
<script>
? import { ref } from 'vue'
? export default {
? ? setup(props) {
? ? ? const count = ref(0)
? ? ? // 暴露給 template 的屬性,可以直接在 template 中使用
? ? ? return {
? ? ? ? count
? ? ? }
? ? }
? }
</script>2、ref 能定義“任何類型”的響應(yīng)式數(shù)據(jù)
如果將 setup 寫在 <script> 標(biāo)簽里,則該標(biāo)簽里的腳本都是執(zhí)行在 setup 里的,并且里面聲明數(shù)據(jù)均會默認(rèn)地暴露給 template,在 template 中使用時(shí)無需加 .value。
例如:
<template>
? <div>{{ name }} : {{ state.age }}</div>
</template>
<script setup>
? import { ref } from 'vue'
? // 為基本數(shù)據(jù)類型添加響應(yīng)式狀態(tài)
? const name = ref('Marry')
? // 為復(fù)雜數(shù)據(jù)類型添加響應(yīng)式狀態(tài)
? const state = ref({
? ? age: 18
? })
? // 打印name的值
? console.log(name.value)
? // 打印count的值
? console.log(state.value.age)
</script>二、reactive——定義響應(yīng)式對象
- 用來定義“對象類型”的響應(yīng)式數(shù)據(jù)。
- 參數(shù)只能傳入對象類型,返回一個(gè)具有響應(yīng)式狀態(tài)的副本。
- 使用 reactive 定義的屬性可以直接使用,不需要加 .value。
- 不要直接解構(gòu)使用 reactive 定義的響應(yīng)式對象,否則會造成該對象脫離 ref 響應(yīng)式。需要用 toRefs 將其轉(zhuǎn)化為響應(yīng)式數(shù)據(jù)對象,然后再解構(gòu)返回。
例如:
<template>
? <div>{{ obj.count }}</div>
</template>
<script setup>
? import { reactive } from 'vue'
??
? const obj = reactive({
? ? count: 0
? })
? // 使用 reactive 定義的屬性可以直接使用,不需要加 .value
? console.log(state.count)
</script>三、toRef——將一個(gè) reactive 轉(zhuǎn)化為一個(gè) ref
- 針對一個(gè)響應(yīng)式對象(reactive 封裝)的 prop(屬性)創(chuàng)建一個(gè) ref,且保持響應(yīng)式兩者 保持引用關(guān)系。
- 接收兩個(gè)參數(shù):源響應(yīng)式對象 和 屬性名,返回一個(gè) ref 數(shù)據(jù)。
- 獲取數(shù)據(jù)值的時(shí)候需要加 .value。
- 使用 toRef 轉(zhuǎn)化后生成的 ref 數(shù)據(jù)如果是引用類型數(shù)據(jù)時(shí),那么它不是原始數(shù)據(jù)的拷貝,而是原始數(shù)據(jù)的引用,改變它的數(shù)據(jù)也會同時(shí)改變原始數(shù)據(jù)。
例如:在 setup 中使用父組件傳遞的 props 數(shù)據(jù)時(shí),要引用 props 的某個(gè)屬性,且要保持響應(yīng)式連接,就必須使用 toRef。
<template>
? <div>{{ myTitle }}</div>
</template>
<script>
? import { defineComponent, toRef } from 'vue'
? export default defineComponent({
? ? props: [title],
? ? setup (props) {
? ? ? // 創(chuàng)建變量myTitle
? ? ? const myTitle = toRef(props, 'title')
? ? ? console.log(myTitle.value)
? ? ? return {
?? ??? ?myTitle
? ? ? }
? ? }
? })
</script>四、toRefs——將多個(gè) reactive 自動解構(gòu)為多個(gè) ref
- toRefs 用于將響應(yīng)式對象轉(zhuǎn)換為普通對象,其中普通對象的每個(gè)屬性都是指向原始對象相應(yīng)屬性的 ref,兩者保持引用關(guān)系。
- toRefs 常用于 ES6 的解構(gòu)賦值操作。但是,對一個(gè)響應(yīng)式對象直接解構(gòu)時(shí),解構(gòu)后的數(shù)據(jù)將不再有響應(yīng)式,而使用 toRefs 可以方便解決這個(gè)問題。
- 獲取數(shù)據(jù)值的時(shí)候需要加 .value。
- 使用 toRefs 轉(zhuǎn)化后生成的 ref 數(shù)據(jù)如果是引用類型數(shù)據(jù)時(shí),那么它不是原始數(shù)據(jù)的拷貝,而是原始數(shù)據(jù)的引用,改變它的數(shù)據(jù)也會同時(shí)改變原始數(shù)據(jù)。
- 其作用和 toRef 類似,只不過 toRef 是對一個(gè)個(gè)屬性手動賦值,而 toRefs 是自動解構(gòu)賦值。
<template>
? <div>{{ myTitle }}</div>
</template>
<script>
? import { defineComponent, toRefs } from 'vue'
? export default defineComponent({
? ? props: [title],
? ? setup (props) {
? ? ? // toRefs 默認(rèn)使用了解構(gòu)賦值,創(chuàng)建了變量 myTitle
? ? ? const { myTitle } = toRefs(props)
? ? ? console.log(myTitle.value)
? ? ? return {
?? ??? ?myTitle
?? ? ?}
? ? }
? })
</script>到此這篇關(guān)于淺談vue3中ref、toRef、toRefs 和 reactive的區(qū)別的文章就介紹到這了,更多相關(guān)vue3 ref toRef toRefs reactive內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
antd配置config-overrides.js文件的操作
這篇文章主要介紹了antd配置config-overrides.js文件的操作,具有很好的參考價(jià)值,希望對大家有所幫助。一起跟隨小編過來看看吧2020-10-10
vue element 多圖片組合預(yù)覽的實(shí)現(xiàn)
本文主要介紹了vue element多圖片預(yù)覽實(shí)現(xiàn)的相關(guān)資料,最近的項(xiàng)目中有圖片預(yù)覽的場景,本文就來介紹一下如何使用,感興趣的可以了解一下2023-08-08
詳解Vue里循環(huán)form表單項(xiàng)實(shí)例
本文主要介紹了Vue里循環(huán)form表單項(xiàng)實(shí)例,文中通過示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2021-09-09
vue實(shí)現(xiàn)給某個(gè)數(shù)據(jù)字段添加顏色
這篇文章主要介紹了vue實(shí)現(xiàn)給某個(gè)數(shù)據(jù)字段添加顏色方式,具有很好的參考價(jià)值,希望對大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2024-03-03
ant design vue嵌套表格及表格內(nèi)部編輯的用法說明
這篇文章主要介紹了ant design vue嵌套表格及表格內(nèi)部編輯的用法說明,具有很好的參考價(jià)值,希望對大家有所幫助。一起跟隨小編過來看看吧2020-10-10
Vite中自制mock服務(wù)器(不使用第三方服務(wù))
本文主要介紹了Vite中自制mock服務(wù)器,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2023-04-04

