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

vue shallowRef作用及引發(fā)問題詳解

 更新時間:2022年08月29日 11:09:20   作者:吳當(dāng)當(dāng)?shù)男逕捗丶? 
這篇文章主要為大家介紹了vue shallowRef作用及引發(fā)問題詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪

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)在我們回到剛才的那個問題,說到triggerRefValuetriggerRef,那他們倆是什么關(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)圖片懶加載的代碼詳解

    這篇文章主要給大家介紹了vue通過vue-lazyload實(shí)現(xiàn)圖片懶加載,文中通過代碼示例給大家介紹的非常詳細(xì),對大家的學(xué)習(xí)或工作有一定的幫助,需要的朋友可以參考下
    2024-02-02
  • vue中的v-if和v-show的區(qū)別詳解

    vue中的v-if和v-show的區(qū)別詳解

    這篇文章主要介紹了vue中的v-if和v-show的區(qū)別詳解,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2019-09-09
  • vue?vue-touch移動端手勢詳解

    vue?vue-touch移動端手勢詳解

    這篇文章主要介紹了vue?vue-touch移動端手勢詳解,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2022-03-03
  • vue菜單欄自適應(yīng)折疊功能示例

    vue菜單欄自適應(yīng)折疊功能示例

    這篇文章主要介紹了vue菜單欄自適應(yīng)折疊,我這里使用的是el-menu導(dǎo)航菜單,監(jiān)聽頁面寬度的改變,來改變導(dǎo)航菜單的折疊和展開,本文結(jié)合示例代碼給大家介紹的非常詳細(xì),需要的朋友可以參考下
    2023-01-01
  • vue3如何解決各場景l(fā)oading過度(避免白屏尷尬!)

    vue3如何解決各場景l(fā)oading過度(避免白屏尷尬!)

    在開發(fā)的過程中點(diǎn)擊提交按鈕,或者是一些其它場景總會遇到loading加載,下面這篇文章主要給大家介紹了關(guān)于vue3如何解決各場景l(fā)oading過度的相關(guān)資料,避免白屏尷尬,需要的朋友可以參考下
    2023-03-03
  • Vue select 綁定動態(tài)變量的實(shí)例講解

    Vue select 綁定動態(tài)變量的實(shí)例講解

    這篇文章主要介紹了Vue select 綁定動態(tài)變量的實(shí)例講解,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2020-10-10
  • 一起來學(xué)習(xí)Vue的生命周期

    一起來學(xué)習(xí)Vue的生命周期

    這篇文章主要為大家詳細(xì)介紹了Vue的生命周期,文中示例代碼介紹的非常詳細(xì),具有一定的參考價值,感興趣的小伙伴們可以參考一下,希望能夠給你帶來幫助
    2022-02-02
  • vue中form表單禁用專用組件介紹

    vue中form表單禁用專用組件介紹

    這篇文章主要介紹了vue中form表單禁用專用組件,具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教
    2024-01-01
  • vue+iview框架實(shí)現(xiàn)左側(cè)動態(tài)菜單功能的示例代碼

    vue+iview框架實(shí)現(xiàn)左側(cè)動態(tài)菜單功能的示例代碼

    這篇文章主要介紹了vue+iview框架實(shí)現(xiàn)左側(cè)動態(tài)菜單功能,本文通過實(shí)例代碼給大家介紹的非常詳細(xì),對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友可以參考下
    2020-07-07
  • 使用Vue?控制元素顯示隱藏的方法和區(qū)別

    使用Vue?控制元素顯示隱藏的方法和區(qū)別

    這篇文章主要介紹了Vue??控制元素顯示隱藏的方法和區(qū)別,需要的朋友可以參考下
    2022-12-12

最新評論