vue shallowRef作用及引發(fā)問題詳解
shallowRef是什么
最近在開發(fā)遇到一個(gè)問題,使用shallowRef居然導(dǎo)致視圖更新了,這一看把我也給搞懵了,后來便仔細(xì)看了看文檔,現(xiàn)在來總結(jié)一下。
ref是一個(gè)定義響應(yīng)式的API,可以通過訪問.value屬性修改并更新到視圖上。
但是shallowRef并不會(huì)被深層遞歸成響應(yīng)式,也就是說使用.value.屬性是不會(huì)更新到試圖上的。只能是替換整個(gè).value才會(huì)更新。
那么我們現(xiàn)在遇到的問題是怎么樣導(dǎo)致的呢?
發(fā)現(xiàn)問題
通過我去注釋代碼,最后只剩下幾行代碼,通過一個(gè)小例子來看看: 比如:
<script setup>
import { shallowRef } from 'vue'
let shallowValue = shallowRef({
age: 10
})
const change = () => {
shallowValue.value.age= 20;
console.log(shallowValue.value) // {age:20}
}
</script>
<template>
<h1>{{ shallowValue }}</h1>
<button @click="change">change shallowRef</button>
</template>

現(xiàn)在是這樣的,當(dāng)我們點(diǎn)擊按鈕時(shí),打印出shallowValue的會(huì)發(fā)現(xiàn)更新啦,但是視圖并未更新。
再定義一個(gè)ref值。同樣在點(diǎn)擊按鈕觸發(fā)的函數(shù)里面改變ref的值。會(huì)發(fā)現(xiàn)不僅是ref的值更新啦,shallowRef的值也更新啦。

這是怎么回事呢?
我們?cè)跒g覽debug一下,發(fā)現(xiàn)執(zhí)行refValue.value觸發(fā)set函數(shù)時(shí)同時(shí)一會(huì)觸發(fā)triggerRefValue函數(shù)。

那triggerRefValue函數(shù)又是什么東東?
triggerRefValue與triggerRef
說到triggerRefValue就可以提到triggerRef(), triggerRef()會(huì)強(qiáng)制觸發(fā)依賴于一個(gè)shallowRef,同時(shí)會(huì)更新視圖.
<script setup>
import { shallowRef,triggerRef } from 'vue'
let refValue = ref("ref舊值")
let shallowValue = shallowRef({
age: 10
})
const change = () => {
shallowValue.value.age= 20;
triggerRef(shallowValue)
// refValue.value = 'ref的新值'
console.log(shallowValue.value)
}
</script>
<template>
<h1>ref的值:{{refValue}}</h1>
<h1>{{ shallowValue }}</h1>
<button @click="change">change shallowRef</button>
</template>
點(diǎn)擊按鈕時(shí)會(huì)發(fā)現(xiàn)視圖同時(shí)也會(huì)更新。

解決問題
現(xiàn)在我們回到剛才的那個(gè)問題,說到triggerRefValue與triggerRef,那他們倆是什么關(guān)系呢? 在觸發(fā)triggerRefValue下面有段代碼。

就是triggerRef函數(shù),而這個(gè)函數(shù)里面就一行代碼,就是triggerRefValue函數(shù),所以說triggerRef的核心功能就是triggerRefValue函數(shù)來做的,上面說到triggerRef會(huì)強(qiáng)制觸發(fā)視圖更新,就等于是triggerRefValue強(qiáng)制視圖更新啦。
以至于在點(diǎn)擊按鈕時(shí)修改ref的值觸發(fā)了triggerRefValue函數(shù),間接影響到了shallowRef的值,才會(huì)使視圖更新。
end
事情就是怎么個(gè)事情,想要解決這個(gè)問題,只能是在開發(fā)時(shí)避免這個(gè)這種寫法。
以上就是vue shallowRef作用及引發(fā)問題詳解的詳細(xì)內(nèi)容,更多關(guān)于vue shallowRef作用的資料請(qǐng)關(guān)注腳本之家其它相關(guān)文章!
相關(guān)文章
vue打包更新packge.json版本號(hào)的全過程
這篇文章主要介紹了vue打包更新packge.json版本號(hào)的全過程,文章通過圖文結(jié)合的方式給大家講解的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作有一定的幫助,需要的朋友可以參考下2024-08-08
vue-mugen-scroll組件實(shí)現(xiàn)pc端滾動(dòng)刷新
這篇文章主要為大家詳細(xì)介紹了vue-mugen-scroll組件實(shí)現(xiàn)pc端滾動(dòng)刷新,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2019-08-08
利用Electron簡(jiǎn)單擼一個(gè)Markdown編輯器的方法
這篇文章主要介紹了利用Electron簡(jiǎn)單擼一個(gè)Markdown編輯器的方法,小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧2019-06-06
詳解Jest結(jié)合Vue-test-utils使用的初步實(shí)踐
這篇文章主要介紹了詳解Jest結(jié)合Vue-test-utils使用的初步實(shí)踐,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2019-06-06
如何在Vue項(xiàng)目中應(yīng)用TypeScript類
與如何在React項(xiàng)目中應(yīng)用TypeScript類類似在VUE項(xiàng)目中應(yīng)用typescript,我們需要引入一個(gè)庫vue-property-decorator,需要的小伙伴可續(xù)看下文具體介紹2021-09-09

