亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

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

 更新時間:2024年11月06日 09:06:59   作者:合格的程序員  
在Vue3中,ref主要用于基本數(shù)據(jù)類型和單個數(shù)據(jù)管理,需要用.value訪問,reactive適用于對象和多數(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. 使用場景不同

ref:

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

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

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

reactive:

  • 主要用于對象類型(Object、Array)
  • 直接訪問屬性,不需要 .value
  • 適合多個響應(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 訪問
  • 在模板中自動解包,直接使用
<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 對象的屬性轉(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)后會失去響應(yīng)性
  • 需要使用 toRefs 保持響應(yīng)性
import { reactive } from 'vue'

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

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

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

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

總結(jié)

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

相關(guān)文章

  • vscode+vue cli3.0創(chuàng)建項目配置Prettier+eslint方式

    vscode+vue cli3.0創(chuàng)建項目配置Prettier+eslint方式

    這篇文章主要介紹了vscode+vue cli3.0創(chuàng)建項目配置Prettier+eslint方式,具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教
    2023-10-10
  • 使用Vue3和p5.js實現(xiàn)交互式圖像動畫

    使用Vue3和p5.js實現(xiàn)交互式圖像動畫

    這篇文章主要介紹了如何用Vue3和p5.js打造一個交互式圖像動畫,文中給出了詳細(xì)的代碼示例,本代碼適用于需要在網(wǎng)頁中實現(xiàn)圖像滑動效果的場景,例如圖片瀏覽、相冊展示等,感興趣的小伙伴跟著小編一起來看看吧
    2024-06-06
  • vue實現(xiàn)局部刷新的實現(xiàn)示例

    vue實現(xiàn)局部刷新的實現(xiàn)示例

    這篇文章主要介紹了vue實現(xiàn)局部刷新的實現(xiàn)示例,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2019-04-04
  • vue 遞歸組件的簡單使用示例

    vue 遞歸組件的簡單使用示例

    這篇文章主要介紹了vue 遞歸組件的簡單使用示例,幫助大家更好的理解和使用vue框架,感興趣的朋友可以了解下
    2021-01-01
  • vue computed無法得到this的屬性或方法的解決

    vue computed無法得到this的屬性或方法的解決

    這篇文章主要介紹了vue computed無法得到this的屬性或方法的解決方案,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2023-07-07
  • vue3路由新玩法useRoute和useRouter詳解

    vue3路由新玩法useRoute和useRouter詳解

    這篇文章主要介紹了vue3路由新玩法useRoute和useRouter,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2022-08-08
  • vue3-HTTP請求方式

    vue3-HTTP請求方式

    這篇文章主要介紹了vue3-HTTP請求方式,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2022-06-06
  • vue3?+?element-plus?的?upload?+?axios?+?django?實現(xiàn)文件上傳并保存功能

    vue3?+?element-plus?的?upload?+?axios?+?django?實現(xiàn)文件上

    這篇文章主要介紹了vue3?+?element-plus?的?upload?+?axios?+?django?文件上傳并保存,本文通過實例代碼給大家介紹的非常詳細(xì),對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友參考下吧
    2024-01-01
  • 從零開始封裝自己的自定義Vue組件

    從零開始封裝自己的自定義Vue組件

    如何封裝自己的Vue組件,如何把自己的Vue代碼封裝成公共組件,今天為大家簡單介紹一下如何封裝自己的Vue組件
    2018-10-10
  • 在pycharm中開發(fā)vue的方法步驟

    在pycharm中開發(fā)vue的方法步驟

    這篇文章主要介紹了在pycharm中開發(fā)vue的方法步驟,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2020-03-03

最新評論