vue shallowRef作用及引發(fā)問題詳解
shallowRef是什么
最近在開發(fā)遇到一個問題,使用shallowRef
居然導(dǎo)致視圖更新了,這一看把我也給搞懵了,后來便仔細(xì)看了看文檔,現(xiàn)在來總結(jié)一下。
ref
是一個定義響應(yīng)式的API
,可以通過訪問.value
屬性修改并更新到視圖上。
但是shallowRef
并不會被深層遞歸成響應(yīng)式,也就是說使用.value.屬性
是不會更新到試圖上的。只能是替換整個.value
才會更新。
那么我們現(xiàn)在遇到的問題是怎么樣導(dǎo)致的呢?
發(fā)現(xiàn)問題
通過我去注釋代碼,最后只剩下幾行代碼,通過一個小例子來看看: 比如:
<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)擊按鈕時,打印出shallowValue
的會發(fā)現(xiàn)更新啦,但是視圖并未更新。
再定義一個ref
值。同樣在點(diǎn)擊按鈕觸發(fā)的函數(shù)里面改變ref
的值。會發(fā)現(xiàn)不僅是ref
的值更新啦,shallowRef
的值也更新啦。
這是怎么回事呢?
我們在瀏覽debug
一下,發(fā)現(xiàn)執(zhí)行refValue.value
觸發(fā)set
函數(shù)時同時一會觸發(fā)triggerRefValue
函數(shù)。
那triggerRefValue
函數(shù)又是什么東東?
triggerRefValue與triggerRef
說到triggerRefValue
就可以提到triggerRef()
, triggerRef()
會強(qiáng)制觸發(fā)依賴于一個shallowRef
,同時會更新視圖.
<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)擊按鈕時會發(fā)現(xiàn)視圖同時也會更新。
解決問題
現(xiàn)在我們回到剛才的那個問題,說到triggerRefValue
與triggerRef
,那他們倆是什么關(guān)系呢? 在觸發(fā)triggerRefValue
下面有段代碼。
就是triggerRef
函數(shù),而這個函數(shù)里面就一行代碼,就是triggerRefValue
函數(shù),所以說triggerRef
的核心功能就是triggerRefValue
函數(shù)來做的,上面說到triggerRef
會強(qiáng)制觸發(fā)視圖更新,就等于是triggerRefValue
強(qiáng)制視圖更新啦。
以至于在點(diǎn)擊按鈕時修改ref
的值觸發(fā)了triggerRefValue
函數(shù),間接影響到了shallowRef
的值,才會使視圖更新。
end
事情就是怎么個事情,想要解決這個問題,只能是在開發(fā)時避免這個這種寫法。
以上就是vue shallowRef作用及引發(fā)問題詳解的詳細(xì)內(nèi)容,更多關(guān)于vue shallowRef作用的資料請關(guān)注腳本之家其它相關(guān)文章!
相關(guān)文章
vue通過vue-lazyload實(shí)現(xiàn)圖片懶加載的代碼詳解
這篇文章主要給大家介紹了vue通過vue-lazyload實(shí)現(xiàn)圖片懶加載,文中通過代碼示例給大家介紹的非常詳細(xì),對大家的學(xué)習(xí)或工作有一定的幫助,需要的朋友可以參考下2024-02-02vue3如何解決各場景l(fā)oading過度(避免白屏尷尬!)
在開發(fā)的過程中點(diǎn)擊提交按鈕,或者是一些其它場景總會遇到loading加載,下面這篇文章主要給大家介紹了關(guān)于vue3如何解決各場景l(fā)oading過度的相關(guān)資料,避免白屏尷尬,需要的朋友可以參考下2023-03-03Vue select 綁定動態(tài)變量的實(shí)例講解
這篇文章主要介紹了Vue select 綁定動態(tài)變量的實(shí)例講解,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧2020-10-10vue+iview框架實(shí)現(xiàn)左側(cè)動態(tài)菜單功能的示例代碼
這篇文章主要介紹了vue+iview框架實(shí)現(xiàn)左側(cè)動態(tài)菜單功能,本文通過實(shí)例代碼給大家介紹的非常詳細(xì),對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友可以參考下2020-07-07