vue3中的reactive、readonly和shallowReactive

在 Vue 3 中,reactivereadonlyshallowReactive 是用于创建响应式对象的函数,它们可以帮助管理组件状态和数据流。下面是它们的详细介绍以及相应的代码示例:

  1. reactive:

    • reactive 函数用于创建一个完全响应式的对象,当对象的属性发生变化时,相关的视图会自动更新。
    javascript 复制代码
    import { reactive } from 'vue';
    
    const state = reactive({
        count: 0,
        message: 'Hello Vue!',
    });
  2. readonly:

    • readonly 函数用于创建一个只读的响应式对象,其属性不能被修改,但如果属性值是对象或数组,则对象内部的属性可以修改。
    javascript 复制代码
    import { readonly } from 'vue';
    
    const readOnlyState = readonly(state);
  3. shallowReactive:

    • shallowReactive 函数与 reactive 类似,但它只会使对象的顶层属性变为响应式,而不会递归地转换嵌套对象的属性。
    javascript 复制代码
    import { shallowReactive } from 'vue';
    
    const shallowState = shallowReactive({
        count: 0,
        nested: {
            message: 'Hello Vue!',
        }
    });

这些函数提供了不同级别的响应式对象,你可以根据需求选择合适的函数来创建对象。在实际应用中,你可以将这些响应式对象用于组件的状态管理、数据传递等场景,从而实现更加灵活和高效的 Vue 应用程序。

相关推荐
kyriewen2 小时前
我手写了一个 EventEmitter,面试官追问了 6 个问题——第 4 个我没答上来
前端·javascript·面试
IT_陈寒2 小时前
Java的Date类又坑了我一次,改用时间戳真香
前端·人工智能·后端
山河木马2 小时前
矩阵专题2-怎么创建视图矩阵(uViewMatrix)
javascript·webgl·计算机图形学
小林攻城狮3 小时前
使用 Transport 节流解决 Vercel AI SDK 流式渲染卡死问题
前端·react.js
前端缘梦3 小时前
告别 TS 运行时类型漏洞!Zod 完整入门实战教程(前端 / 全栈必备)
前端·react.js·全栈
the_answer3 小时前
Webpack vs Vite 深度对比分析
前端·webpack
转转技术团队3 小时前
验证码识别实战:前端不写页面,改训模型了?
前端
MomentYY3 小时前
Temperature:AI 的“脑洞旋钮”
前端·llm·ai编程
远航_4 小时前
OpenSpec 完整详细介绍
前端·后端
召钱熏4 小时前
状态枚举正确≠渲染正确:一个语音按钮的状态机边界修复实录
android·前端