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 应用程序。

相关推荐
想你依然心痛9 小时前
AtomCode 在前端开发中的实战体验:React + TypeScript 项目开发实录
前端·react.js·typescript
疯狂的魔鬼9 小时前
精确计算容器剩余视口高度:useAutoContainerFullHeight 的工程实践
前端·css·typescript
Esaka_Forever9 小时前
Python 与 JS (V8) 垃圾回收核心区别 + 底层根源分析
开发语言·javascript·jvm
用户059540174469 小时前
用了 3 个月 ChatGPT,才发现它一直在遗忘——用 Playwright 自动化验证记忆存储一致性
前端·css
玄玄子9 小时前
xss前端解决方案
前端·浏览器·xss
林希_Rachel_傻希希9 小时前
web性能优化之——AI总结视频
前端·javascript·面试
前端炒粉9 小时前
个人简历面经总结二
前端·网络·vue.js·react.js·面试
binbin_529 小时前
UIAbility 与 WindowStage:窗口创建、加载、销毁的完整链路
开发语言·javascript·深度学习·华为·harmonyos
用户059540174469 小时前
用了半年 LangChain Memory,才发现回滚测试压根没测对
前端·css
木木的木云9 小时前
从零构建微前端框架:PavilionMfe 设计揭秘
前端·架构·vite