【Vue3】shallowReactive() and shallowReadonly()

历史小剧场

所谓历史,就是过去的事,它的残酷之处在于:无论你哀嚎,悲伤,痛苦,落寞,追悔,它都无法改变。
一具有名的尸体躺在无数无名的尸体上,这就是所谓的霸业。---- 《明朝那些事儿》

shallowReactive

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

<!-- 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

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

 const person = shallowReadonly({
    name: '新潮',
     info: {
         age: 25
     }
 })

 console.log("第一层 => ", isReadonly(person))       // true
 console.log("第二层 => ", isReadonly(person.info))  // false

相关推荐

  1. vue 3

    2024-06-06 07:38:02       53 阅读
  2. <span style='color:red;'>Vue</span>-<span style='color:red;'>3</span>

    Vue-3

    2024-06-06 07:38:02      32 阅读
  3. <span style='color:red;'>vue</span><span style='color:red;'>3</span>~

    vue3~

    2024-06-06 07:38:02      25 阅读
  4. <span style='color:red;'>Vue</span>-<span style='color:red;'>vue</span><span style='color:red;'>3</span>

    Vue-vue3

    2024-06-06 07:38:02      43 阅读
  5. vue2和vue3

    2024-06-06 07:38:02       36 阅读
  6. Vue】创建vue3项目

    2024-06-06 07:38:02       44 阅读
  7. vue2-vue3面试

    2024-06-06 07:38:02       28 阅读

最近更新

  1. docker php8.1+nginx base 镜像 dockerfile 配置

    2024-06-06 07:38:02       94 阅读
  2. Could not load dynamic library ‘cudart64_100.dll‘

    2024-06-06 07:38:02       100 阅读
  3. 在Django里面运行非项目文件

    2024-06-06 07:38:02       82 阅读
  4. Python语言-面向对象

    2024-06-06 07:38:02       91 阅读

热门阅读

  1. rust之cargo install cargo-binstall 是什么

    2024-06-06 07:38:02       25 阅读
  2. maxwell同步mysql到kafka(一个服务器启动多个)

    2024-06-06 07:38:02       20 阅读
  3. TCP/IP 接收发送缓存大小的自动调优 Auto Tuning

    2024-06-06 07:38:02       27 阅读
  4. 《解锁创意无限:Stable Diffusion 详细教程指南》

    2024-06-06 07:38:02       28 阅读
  5. 洛谷 P8740 [蓝桥杯 2021 省 A] 填空问题 题解

    2024-06-06 07:38:02       26 阅读
  6. folyd算法求最短路径

    2024-06-06 07:38:02       43 阅读
  7. AudioSet 本体与声音实体对象

    2024-06-06 07:38:02       29 阅读
  8. Android AAudio——C API创建AudioTrack(六)

    2024-06-06 07:38:02       27 阅读
  9. 力扣2831.找出最长等值子数组

    2024-06-06 07:38:02       29 阅读
  10. axios

    axios

    2024-06-06 07:38:02      29 阅读