你知道为什么ref不能与shallowRef一起使用吗

前言

在尝试Vue.js的官网文档案例中发现

运用 @click 事件改变ref以及shallowRef的时候发现会同时进行

过程复现

首先我们来举一个例子

vue 复制代码
<script setup lang="ts">
import {ref,shallowRef} from 'vue'

const msgRef = ref({mgs:'a'})

const mgsShallowRef = shallowRef({mgs:'b'})

cosnt change = () => {
    msgRef.value.msg = 'aaaaa' 
    mgsShallowRef.value.msg = 'bbbbb' 
    console.log(mgsShallowRef)
}
</script>

<template>
    <div>
        ref: {{msgRef}}
    </div>
    <div>
        shallowRef: {{mgsShallowRef}}
    </div>
    <button @click="change">改变</button>
</template>

点击按钮改变

按照 shallowRef 的概念中 他改变是属于浅层次的响应内容

虽然打印出来的 mgsShallowRef.value 改变了 在理想状态中页面是 shallowRef: {{mgsShallowRef}} 不会发生改变的

但是实际上发生的却是 页面中的 shallowRef: {{mgsShallowRef}} 变为了 bbbbb

解答

发生了这样子的情况 肯定是抱有疑惑的 这就去看了看ref的源码

发现他调用了triggerRef这个东西

于是去官网查看了一下

发现了他确实有改变的这个效果

想要复现这个问题 只需要简单的改变一下

vue 复制代码
<script setup lang="ts">
import {ref,shallowRef,triggerRef} from 'vue'

const msgRef = ref({mgs:'a'})

const mgsShallowRef = shallowRef({mgs:'b'})

cosnt change = () => {
    mgsShallowRef.value.msg = 'bbbbb' 
    triggerRef(mgsShallowRef)
    console.log(mgsShallowRef)
}
</script>

只是需要这样子调用一下 triggerRef(mgsShallowRef) 便能够复现上述的问题 造成视图的更新

所以说 triggerRef 这个会强制更新收集到的变化 所以造成了这样子的效果

探讨

想要增加一下防御型代码 shallowRef 加上triggerRef 是不是也可以做到 ref 相同的效果呢

相关推荐
customer0829 分钟前
【开源免费】基于SpringBoot+Vue.JS个人博客系统(JAVA毕业设计)
java·vue.js·spring boot·后端·开源
乐多_L1 小时前
使用vue3框架vue-next-admin导出表格excel(带图片)
前端·javascript·vue.js
初尘屿风1 小时前
基于微信小程序的电影院订票选座系统的设计与实现,SSM+Vue+毕业论文+开题报告+任务书+指导搭建视频
vue.js·微信小程序·小程序
南望无一1 小时前
React Native 0.70.x如何从本地安卓源码(ReactAndroid)构建
前端·react native
Mike_188702783511 小时前
1688代采下单API接口使用指南:实现商品采集与自动化下单
前端·python·自动化
customer081 小时前
【开源免费】基于SpringBoot+Vue.JS打卡健康评测系统(JAVA毕业设计)
java·vue.js·spring boot·后端·开源
鲨鱼辣椒️面1 小时前
HTML视口动画
前端·html
一小路一1 小时前
Go Web 开发基础:从入门到实战
服务器·前端·后端·面试·golang
堇舟1 小时前
HTML第一节
前端·html
纯粹要努力1 小时前
前端跨域问题及解决方案
前端·javascript·面试