【Vue3】shallowReactive() and shallowReadonly()

历史小剧场

所谓历史,就是过去的事,它的残酷之处在于:无论你哀嚎,悲伤,痛苦,落寞,追悔,它都无法改变。

一具有名的尸体躺在无数无名的尸体上,这就是所谓的霸业。---- 《明朝那些事儿》

shallowReactive

只有根级别的属性是响应式的

看案例

js 复制代码
<!-- TestShallow.vue -->
<template>
    <div>
        <p>学号: {{ id }}&nbsp;&nbsp;姓名: {{ info.name }}</p>
        <button @click="id++">点击增加学号</button>
        <button @click="changeName">改变姓名</button>
    </div>
</template>

<script lang="ts">
import { isReadonly, shallowReactive, shallowReadonly, toRefs } from 'vue';

export default {
    name: 'TestShallow',
    setup() {
        type Student = {
            id: number,
            info: {
                name: string,
            }
        }

        const student = shallowReactive<Student>({
            id: 1,
            info: {
                name: '张三'  // 这里的name不是响应式的
            }
        })

        const changeName = () => {
            student.info.name = '莉丝'
            console.log("name => ", student.info.name)
        }

        return {
            ...toRefs(student),
            changeName
        }
    }
}
</script>

<style lang="scss" scoped>

</style>

当我们点击增加学号时,界面上学号+1;

但是,我们点击修改姓名是,只有控制台打印的姓名变了,而界面上却没变。

这就是说明,这里在info里面的属性不是响应式的

shallowReadonly

只有根节点的属性是只读的

js 复制代码
 const person = shallowReadonly({
    name: '新潮',
     info: {
         age: 25
     }
 })

 console.log("第一层 => ", isReadonly(person))       // true
 console.log("第二层 => ", isReadonly(person.info))  // false
相关推荐
别拿曾经看以后~33 分钟前
【el-form】记一例好用的el-input输入框回车调接口和el-button按钮防重点击
javascript·vue.js·elementui
我要洋人死36 分钟前
导航栏及下拉菜单的实现
前端·css·css3
川石课堂软件测试39 分钟前
性能测试|docker容器下搭建JMeter+Grafana+Influxdb监控可视化平台
运维·javascript·深度学习·jmeter·docker·容器·grafana
科技探秘人1 小时前
Chrome与火狐哪个浏览器的隐私追踪功能更好
前端·chrome
科技探秘人1 小时前
Chrome与傲游浏览器性能与功能的深度对比
前端·chrome
JerryXZR1 小时前
前端开发中ES6的技术细节二
前端·javascript·es6
七星静香1 小时前
laravel chunkById 分块查询 使用时的问题
java·前端·laravel
q2498596931 小时前
前端预览word、excel、ppt
前端·word·excel
小华同学ai1 小时前
wflow-web:开源啦 ,高仿钉钉、飞书、企业微信的审批流程设计器,轻松打造属于你的工作流设计器
前端·钉钉·飞书
problc1 小时前
Flutter中文字体设置指南:打造个性化的应用体验
android·javascript·flutter