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

前端vue3中的ref與reactive用法及區(qū)別總結(jié)

 更新時(shí)間:2024年08月14日 09:25:18   作者:是個(gè)忙人.  
這篇文章主要給大家介紹了關(guān)于前端vue3中的ref與reactive用法及區(qū)別的相關(guān)資料,關(guān)于ref及reactive的用法,還是要在開(kāi)發(fā)中多多使用,遇到響應(yīng)式失效問(wèn)題,文中通過(guò)代碼介紹的非常詳細(xì),需要的朋友可以參考下

ref與reactive的區(qū)別

接收值的類(lèi)型不同

  • refref可以處理基礎(chǔ)類(lèi)型的值,也可以處理引用類(lèi)型的值。
const ref1 = ref(0)            // true
const ref2 = ref({ count: 0 }) // true

用于創(chuàng)建一個(gè)響應(yīng)式的基本數(shù)據(jù)類(lèi)型時(shí),比如數(shù)字、字符串等。它將普通的數(shù)據(jù)變成響應(yīng)式數(shù)據(jù),可以監(jiān)聽(tīng)數(shù)據(jù)的變化。使用ref時(shí),我們可以通過(guò).value來(lái)訪(fǎng)問(wèn)和修改數(shù)據(jù)的值。

  • reactivereactive僅處理引用類(lèi)型的值,不允許傳遞基礎(chǔ)類(lèi)型的值。
const reactive1 = reactive(0)            // false
const reactive2 = reactive({ count: 0 }) // true

reactive用于創(chuàng)建一個(gè)響應(yīng)式對(duì)象,可以包含多個(gè)屬性。通過(guò)reactive,我們可以將整個(gè)對(duì)象變成響應(yīng)式,使對(duì)象的任何屬性發(fā)生變化時(shí)都能被檢測(cè)到。

訪(fǎng)問(wèn)數(shù)據(jù)的方式不同

對(duì)于 ref來(lái)說(shuō),無(wú)論是原始類(lèi)型還是對(duì)象,訪(fǎng)問(wèn)數(shù)據(jù)都需要通過(guò) .value的形式進(jìn)行,更新數(shù)據(jù)也需要通過(guò) .value來(lái)更新。

<template>
      <div>{{ dxc }}</div>
</template>
 
<script setup>
    import { ref } from 'vue'
    const dxc = ref(0)
</script>

但在<template>中使用ref的值時(shí)不需要帶上.value。

const ref1 = ref(0) 
console.log(ref1.value)  // 0
 
const ref2 = ref({ count: 0 })
console.log(ref2.value.count)  // 0
 
ref1.value = 1
console.log(ref1.value)  // 1

watch監(jiān)聽(tīng)方式不同

  • ref可以直接監(jiān)聽(tīng)數(shù)據(jù),當(dāng)數(shù)據(jù)發(fā)生變化的時(shí)候,就會(huì)執(zhí)行 watch 函數(shù)對(duì)應(yīng)的回調(diào)。
const ref1 = ref(0)
watch(ref1, () => { 
  console.log('changed!')
})

這里只是原始類(lèi)型數(shù)據(jù),如果是對(duì)象的話(huà),需要深度監(jiān)聽(tīng)deep:true

const ref1 = ref({num: 1})
watch(ref1, () => { 
    console.log('changed!')
})
 
// ref1.value.num = 1 
// 執(zhí)行該語(yǔ)句時(shí)并不會(huì)觸發(fā)watch監(jiān)聽(tīng),watch 并沒(méi)有對(duì)ref1進(jìn)行深度監(jiān)聽(tīng)
// 但注意,此時(shí)dom是能更新的,ref會(huì)將其轉(zhuǎn)換成 reactive 的形式
 
// 要想深入監(jiān)聽(tīng),只需要加一個(gè)對(duì)應(yīng)的參數(shù)即可
const ref1 = ref({num: 1})
watch(ref1, () => { 
    console.log('changed!')
}, { deep: true })
  • reactive因?yàn)楸举|(zhì)是對(duì)象,所以在 watch 的時(shí)候本能的會(huì)添加 deep 屬性。vue 對(duì)其做了優(yōu)化 watch 監(jiān)聽(tīng) reactive 的時(shí)候可以不添加 deep 屬也能夠?qū)ζ渥錾疃缺O(jiān)聽(tīng)。
const reactive1 = reactive({num: 1})
watch(reactive1, () => { 
    console.log('changed!')
})
// reactive1.num = 1
// 觸發(fā)watch監(jiān)聽(tīng)

Ref基本用法及在setup()中的使用

基本用法

Vue3中,ref用于創(chuàng)建一個(gè)響應(yīng)式的基本數(shù)據(jù)類(lèi)型,如數(shù)字、字符串等。通過(guò)ref()函數(shù)創(chuàng)建一個(gè)ref對(duì)象,然后可以通過(guò).value來(lái)訪(fǎng)問(wèn)和修改數(shù)據(jù)值。

import { ref } from 'vue';

const count = ref(0); // 創(chuàng)建一個(gè)Ref對(duì)象,初始值為0
console.log(count.value); // 訪(fǎng)問(wèn)Ref對(duì)象的值
count.value = 1; // 修改Ref對(duì)象的值

在setup()中使用

setup()函數(shù)中,我們可以使用ref()來(lái)創(chuàng)建響應(yīng)式數(shù)據(jù),以便在組件中使用。

import { ref } from 'vue';

export default {
  setup() {
    const count = ref(0);
    return {
      count
    };
  }
};

<script setup>語(yǔ)法是一種簡(jiǎn)潔的寫(xiě)法,可以在單文件組件中更便捷地使用ref。

<script setup>
import { ref } from 'vue';

const count = ref(0);
</script>

Reactive基本概念及在模板中的使用

基本概念

Vue3中,reactive用于創(chuàng)建一個(gè)響應(yīng)式對(duì)象,使對(duì)象的屬性發(fā)生變化時(shí)能夠被檢測(cè)到。通過(guò)reactive()函數(shù)創(chuàng)建一個(gè)響應(yīng)式對(duì)象,對(duì)象的所有屬性都變成響應(yīng)式。

import { reactive } from 'vue';

const user = reactive({
  name: 'Alice',
  age: 30
});

在模板中使用Reactive

在模板中可以直接使用響應(yīng)式對(duì)象,對(duì)對(duì)象的屬性進(jìn)行訪(fǎng)問(wèn)和修改。

<template>
  <div>
    <p>Name: {{ user.name }}</p>
    <p>Age: {{ user.age }}</p>
  </div>
</template>

<script>
import { reactive } from 'vue';

export default {
  setup() {
    const user = reactive({
      name: 'Alice',
      age: 30
    });

    return { user };
  }
};
</script>

ref與reactive用法總結(jié)

ref

  • 基本用法Ref用于創(chuàng)建一個(gè)響應(yīng)式的基本數(shù)據(jù)類(lèi)型,如數(shù)字、字符串等。通過(guò)ref函數(shù)創(chuàng)建,訪(fǎng)問(wèn)和修改數(shù)據(jù)值需要使用.value
  • 在setup()中使用:在setup()函數(shù)中,我們可以使用ref來(lái)創(chuàng)建響應(yīng)式數(shù)據(jù),并在模板中使用。
  • <script setup>語(yǔ)法<script setup>語(yǔ)法是Vue3推薦的一種寫(xiě)法,可以在單文件組件中更簡(jiǎn)潔地使用ref。
  • 為何使用refRef適用于管理簡(jiǎn)單的基本數(shù)據(jù)類(lèi)型,如數(shù)字、字符串等。

reactive

  • 基本概念Reactive用于創(chuàng)建一個(gè)響應(yīng)式對(duì)象,可以包含多個(gè)屬性。通過(guò)reactive函數(shù)創(chuàng)建,對(duì)象的任何屬性變化都會(huì)被檢測(cè)到。
  • 在模板中使用Reactive:在模板中可以直接使用響應(yīng)式對(duì)象,對(duì)對(duì)象的屬性進(jìn)行訪(fǎng)問(wèn)和修改。
  • 深層響應(yīng)式Reactive會(huì)遞歸地將對(duì)象的所有嵌套屬性都變成響應(yīng)式。
  • 與ref區(qū)別Ref適用于簡(jiǎn)單數(shù)據(jù)類(lèi)型,而Reactive適用于對(duì)象,可以處理對(duì)象的多個(gè)屬性。
  • 為何使用ReactiveReactive適用于管理復(fù)雜對(duì)象,使整個(gè)對(duì)象都變成響應(yīng)式。

附:ref和reactive定義數(shù)組對(duì)比

使用ref定義數(shù)組舉例如下

const tableData = ref([]) // 定義

const getTableData = async () => {
	const { data } = await getTableDataApi() // 模擬接口獲取表格數(shù)據(jù)
	tableData.value = data // 修改
}
<!-- Vue3模板引用使用 -->
<a-table v-model:dataSource="tableData"></a-table>

圖中以我們常用的表格數(shù)據(jù)舉例,可以看到,ref定義數(shù)組與定義基本數(shù)據(jù)類(lèi)型沒(méi)什么差別,接下來(lái)看看reactive

const tableData = reactive([]) // 定義

const getTableData = async () => {
	const { data } = await getTableDataApi() // 模擬接口獲取表格數(shù)據(jù)
	tableData = data // 修改,錯(cuò)誤示例,這樣賦值會(huì)使tableData失去響應(yīng)式
}
<!-- Vue3模板引用使用 -->
<a-table v-model:dataSource="tableData"></a-table>

需要注意的是,使用 tableData = data 的修改方式會(huì)造成 tableData 響應(yīng)式丟失,解決方法如下(供參考)

// 方法一:改為 ref 定義
const tableData = ref([])
const getTableData = async () => {
	const { data } = await getTableDataApi()
	tableData.value = data // 使用.value重新賦值
}
// 方法二:使用 push 方法
const tableData = reactive([])
const getTableData = async () => {
	const { data } = await getTableDataApi()
	tableData.push(...data) // 先使用...將data解構(gòu),再使用push方法
}
// 方法三:定義時(shí)數(shù)組外層嵌套一個(gè)對(duì)象
const tableData = reactive({ list:[] })
const getTableData = async () => {
	const { data } = await getTableDataApi()
	tableData.list = data // 通過(guò)訪(fǎng)問(wèn)list屬性重新賦值
}
// 方法四:賦值前再包一層 reactive
const tableData = reactive([])
const getTableData = async () => {
	const { data } = await getTableDataApi()
	tableData = reactive(data) // 賦值前再包一層reactive
}

總結(jié) 

到此這篇關(guān)于前端vue3中的ref與reactive用法及區(qū)別總結(jié)的文章就介紹到這了,更多相關(guān)vue3中ref與reactive內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • vue選項(xiàng)卡Tabs組件實(shí)現(xiàn)示例詳解

    vue選項(xiàng)卡Tabs組件實(shí)現(xiàn)示例詳解

    這篇文章主要為大家介紹了vue選項(xiàng)卡Tabs組件實(shí)現(xiàn)示例詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪
    2022-11-11
  • vue中ant-design-vue組件的安裝與使用

    vue中ant-design-vue組件的安裝與使用

    Ant Design Vue是使用Vue實(shí)現(xiàn)的遵循Ant Design設(shè)計(jì)規(guī)范的高質(zhì)量UI組件庫(kù),用于開(kāi)發(fā)和服務(wù)于企業(yè)級(jí)中后臺(tái)產(chǎn)品,下面這篇文章主要給大家介紹了關(guān)于vue中ant-design-vue組件安裝與使用的相關(guān)資料,需要的朋友可以參考下
    2022-04-04
  • vue3中ref和reactive的用法和解析(推薦)

    vue3中ref和reactive的用法和解析(推薦)

    這篇文章主要介紹了vue3的ref和reactive的用法和解析,開(kāi)始部分講解了ref,reactive的使用實(shí)例,如何進(jìn)行類(lèi)型的標(biāo)注,配合ts這么使用,接著講解了兩者的區(qū)別,分別需要注意的點(diǎn),還有ref的頂層自動(dòng)解包,需要的朋友可以參考下
    2023-03-03
  • vue3獲取當(dāng)前路由地址的兩種方法

    vue3獲取當(dāng)前路由地址的兩種方法

    近期在做ve3的項(xiàng)目時(shí)因?yàn)楣δ苄枰?需要獲取當(dāng)前路由的地址,下面這篇文章主要給大家介紹了關(guān)于vue3獲取當(dāng)前路由地址的兩種方法,文中通過(guò)實(shí)例代碼介紹的非常詳細(xì),需要的朋友可以參考下
    2022-10-10
  • vue 項(xiàng)目中的this.$get,this.$post等$的用法案例詳解

    vue 項(xiàng)目中的this.$get,this.$post等$的用法案例詳解

    vue.js的插件應(yīng)該暴露一個(gè)install方法。這個(gè)方法的第一個(gè)參數(shù)是vue構(gòu)造器,第二個(gè)參數(shù)是一個(gè)可選的選項(xiàng)對(duì)象,首頁(yè)要安裝axios,本文結(jié)合案例代碼給大家詳細(xì)講解vue 中的this.$get,this.$post等$的用法,一起學(xué)習(xí)下吧
    2022-12-12
  • Vue3如何通過(guò)ESLint校驗(yàn)代碼是否符合規(guī)范詳解

    Vue3如何通過(guò)ESLint校驗(yàn)代碼是否符合規(guī)范詳解

    ESLint可以靈活設(shè)置規(guī)則,也發(fā)布了很多公開(kāi)的規(guī)則集,下面這篇文章主要給大家介紹了關(guān)于Vue3如何通過(guò)ESLint校驗(yàn)代碼是否符合規(guī)范的相關(guān)資料,文中通過(guò)圖文介紹的非常詳細(xì),需要的朋友可以參考下
    2022-07-07
  • vue中引用阿里字體圖標(biāo)的方法

    vue中引用阿里字體圖標(biāo)的方法

    這篇文章主要介紹了vue中引用阿里字體圖標(biāo)出現(xiàn)錯(cuò)誤問(wèn)題的解決方法,感興趣的朋友跟隨腳本之家小編一起學(xué)習(xí)吧
    2018-02-02
  • vue實(shí)現(xiàn)登錄時(shí)滑塊驗(yàn)證

    vue實(shí)現(xiàn)登錄時(shí)滑塊驗(yàn)證

    這篇文章主要為大家詳細(xì)介紹了vue實(shí)現(xiàn)登錄時(shí)滑塊驗(yàn)證,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2022-03-03
  • 詳解vue-cli 快速搭建單頁(yè)應(yīng)用之遇到的問(wèn)題及解決辦法

    詳解vue-cli 快速搭建單頁(yè)應(yīng)用之遇到的問(wèn)題及解決辦法

    這篇文章主要介紹了詳解vue-cli 快速搭建單頁(yè)應(yīng)用之遇到的問(wèn)題及解決辦法,小編覺(jué)得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧
    2018-03-03
  • vue-cli 介紹與安裝

    vue-cli 介紹與安裝

    這篇文章主要給大家介紹的是vue-cli 介紹與安裝,vue-cli是和vue進(jìn)行深度組合的工具,可以快速幫我們創(chuàng)建vue項(xiàng)目,并且把一些腳手架相關(guān)的代碼給我們創(chuàng)建好。真正使用vue開(kāi)發(fā)項(xiàng)目,都是用vue-cli來(lái)創(chuàng)建項(xiàng)目的,下面文章詳細(xì)內(nèi)容,需要的朋友可以參考一下
    2021-10-10

最新評(píng)論