欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

Vue3中ref和reactive的區(qū)別及說明

 更新時(shí)間:2024年11月06日 09:06:59   作者:合格的程序員  
在Vue3中,ref主要用于基本數(shù)據(jù)類型和單個(gè)數(shù)據(jù)管理,需要用.value訪問,reactive適用于對(duì)象和多數(shù)據(jù)管理,直接訪問屬性,ref支持解構(gòu)保持響應(yīng)性,reactive解構(gòu)后失去響應(yīng)性,選擇合適的方法可以使代碼更優(yōu)化

Vue3 ref和reactive的區(qū)別

在 Vue 3 中,refreactive 都是用來創(chuàng)建響應(yīng)式數(shù)據(jù)的方法

但它們有以下主要區(qū)別:

1. 使用場(chǎng)景不同

ref:

  • 主要用于基本數(shù)據(jù)類型(String、Number、Boolean 等)
  • 也可以用于對(duì)象/數(shù)組,但需要通過 .value 訪問
  • 適合單個(gè)響應(yīng)式數(shù)據(jù)的管理
import { ref } from 'vue'

// 基本類型
const count = ref(0)
console.log(count.value) // 0

// 對(duì)象類型
const user = ref({
  name: 'Tom',
  age: 18
})
console.log(user.value.name) // 'Tom'

reactive:

  • 主要用于對(duì)象類型(Object、Array)
  • 直接訪問屬性,不需要 .value
  • 適合多個(gè)響應(yīng)式數(shù)據(jù)的管理
import { reactive } from 'vue'

const state = reactive({
  name: 'Tom',
  age: 18,
  hobbies: ['reading', 'swimming']
})
console.log(state.name) // 'Tom'

2. 訪問方式不同

ref:

  • 在 setup 中需要通過 .value 訪問
  • 在模板中自動(dòng)解包,直接使用
<script setup>
import { ref } from 'vue'

const count = ref(0)
// setup 中需要 .value
const increment = () => {
  count.value++
}
</script>

<template>
  <!-- 模板中直接使用,不需要 .value -->
  <div>{{ count }}</div>
</template>

reactive:

  • 直接訪問屬性,不需要 .value
  • 在模板和 setup 中的訪問方式相同
<script setup>
import { reactive } from 'vue'

const state = reactive({
  count: 0
})
// 直接訪問
const increment = () => {
  state.count++
}
</script>

<template>
  <!-- 直接訪問 -->
  <div>{{ state.count }}</div>
</template>

3. 解構(gòu)行為不同

ref:

  • 支持解構(gòu),解構(gòu)后仍然保持響應(yīng)性
  • 可以使用 toRefs 將 reactive 對(duì)象的屬性轉(zhuǎn)換為 ref
import { ref, toRefs } from 'vue'

const user = reactive({
  name: ref('Tom'),
  age: ref(18)
})

// ref 解構(gòu)后保持響應(yīng)性
const { name, age } = toRefs(user)
name.value = 'Jerry' // 仍然是響應(yīng)式的

reactive:

  • 解構(gòu)后會(huì)失去響應(yīng)性
  • 需要使用 toRefs 保持響應(yīng)性
import { reactive } from 'vue'

const state = reactive({
  name: 'Tom',
  age: 18
})

// 直接解構(gòu)會(huì)失去響應(yīng)性
const { name, age } = state
name = 'Jerry' // 不再是響應(yīng)式的

// 使用 toRefs 保持響應(yīng)性
const { name, age } = toRefs(state)
name.value = 'Jerry' // 仍然是響應(yīng)式的

4. 使用建議

  1. 使用 ref 的場(chǎng)景:
    • 基本數(shù)據(jù)類型的響應(yīng)式
    • 需要解構(gòu)的響應(yīng)式數(shù)據(jù)
    • 單個(gè)響應(yīng)式數(shù)據(jù)的管理
const count = ref(0)
const message = ref('hello')
const isVisible = ref(true)
  1. 使用 reactive 的場(chǎng)景:
    • 復(fù)雜對(duì)象的響應(yīng)式
    • 多個(gè)相關(guān)數(shù)據(jù)的組合
    • 不需要解構(gòu)的數(shù)據(jù)管理
const state = reactive({
  user: {
    name: 'Tom',
    age: 18
  },
  settings: {
    theme: 'dark',
    notifications: true
  }
})
  1. 混合使用:
    • 可以在 reactive 對(duì)象中使用 ref
    • 使用 toRefs 轉(zhuǎn)換 reactive 對(duì)象為 ref
const state = reactive({
  count: ref(0),
  user: {
    name: ref('Tom'),
    age: ref(18)
  }
})

// 轉(zhuǎn)換為 ref
const { count, user } = toRefs(state)

通過理解這些區(qū)別,你可以根據(jù)具體場(chǎng)景選擇合適的響應(yīng)式方案,使代碼更加清晰和易于維護(hù)。

總結(jié)

以上為個(gè)人經(jīng)驗(yàn),希望能給大家一個(gè)參考,也希望大家多多支持腳本之家。

相關(guān)文章

  • Vue分析同步和異步有什么區(qū)別

    Vue分析同步和異步有什么區(qū)別

    這篇文章主要介紹了Vue分析同步和異步有什么區(qū)別,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)吧
    2023-05-05
  • vue2.0 路由不顯示router-view的解決方法

    vue2.0 路由不顯示router-view的解決方法

    下面小編就為大家分享一篇vue2.0 路由不顯示router-view的解決方法,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過來看看吧
    2018-03-03
  • Vue實(shí)現(xiàn)頁面刷新跳轉(zhuǎn)到當(dāng)前頁面功能

    Vue實(shí)現(xiàn)頁面刷新跳轉(zhuǎn)到當(dāng)前頁面功能

    在Vue.js應(yīng)用開發(fā)中,有時(shí)候我們需要實(shí)現(xiàn)頁面的刷新或跳轉(zhuǎn)到當(dāng)前頁面的功能,這種需求在某些特定場(chǎng)景下非常有用,本文將詳細(xì)介紹如何在Vue中實(shí)現(xiàn)頁面刷新和跳轉(zhuǎn)到當(dāng)前頁面的功能,并提供多個(gè)示例和使用技巧,需要的朋友可以參考下
    2024-10-10
  • element-ui點(diǎn)擊查看大圖的方法示例

    element-ui點(diǎn)擊查看大圖的方法示例

    這篇文章主要介紹了element-ui查看大圖的方法示例,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2020-12-12
  • vue中關(guān)于confirm確認(rèn)框的用法

    vue中關(guān)于confirm確認(rèn)框的用法

    這篇文章主要介紹了vue中關(guān)于confirm確認(rèn)框的用法,具有很好的參考價(jià)值,希望對(duì)大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2023-08-08
  • vue+flask實(shí)現(xiàn)視頻合成功能(拖拽上傳)

    vue+flask實(shí)現(xiàn)視頻合成功能(拖拽上傳)

    這篇文章主要介紹了vue+flask實(shí)現(xiàn)視頻合成功能(拖拽上傳),本文通過實(shí)例代碼給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下
    2021-03-03
  • Vue-不允許嵌套式的渲染方法

    Vue-不允許嵌套式的渲染方法

    今天小編就為大家分享一篇Vue-不允許嵌套式的渲染方法,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過來看看吧
    2018-09-09
  • vue 對(duì)axios get pust put delete封裝的實(shí)例代碼

    vue 對(duì)axios get pust put delete封裝的實(shí)例代碼

    在本篇文章里我們給各位整理的是一篇關(guān)于vue 對(duì)axios get pust put delete封裝的實(shí)例代碼內(nèi)容,有需要的朋友們可以參考下。
    2020-01-01
  • 對(duì)vue2.0中.vue文件頁面跳轉(zhuǎn)之.$router.push的用法詳解

    對(duì)vue2.0中.vue文件頁面跳轉(zhuǎn)之.$router.push的用法詳解

    今天小編就為大家分享一篇對(duì)vue2.0中.vue文件頁面跳轉(zhuǎn)之.$router.push的用法詳解,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過來看看吧
    2018-08-08
  • vue element-ui使用required進(jìn)行表單校驗(yàn)時(shí)自定義提示語問題

    vue element-ui使用required進(jìn)行表單校驗(yàn)時(shí)自定義提示語問題

    這篇文章主要介紹了vue element-ui使用required進(jìn)行表單校驗(yàn)時(shí)自定義提示語問題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2023-05-05

最新評(píng)論