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

相关推荐
naildingding18 分钟前
Vue基础核心
前端·vue.js
弱鸡前端20 分钟前
纯前端实现pdf从生成到下载
前端
明月_清风27 分钟前
TanStack + Cloudflare 边缘实战:从 0 到 1 构建全栈应用
前端·全栈
东风破_27 分钟前
你天天用的 Python dict,90% 的人没搞懂这三个坑
前端
Delicate28 分钟前
JavaScript的“变脸”艺术:类型转换戏法大揭秘
javascript
前端Hardy30 分钟前
21.8 万周下载!这个 React 表格组件,10 行代码就能跑起来
前端·javascript·后端
lichenyang45332 分钟前
# 鸿蒙 ArkTS 聊天 Demo 功能复盘:真实 SSE、多轮会话、暂停输出、历史记录与防崩溃修复 > 项目:`harmony-chat-demo`
前端
陈_杨35 分钟前
鸿蒙APP开发-带你走进胶片录的拍摄记录管理
前端·javascript
陈_杨41 分钟前
鸿蒙APP开发-带你走进胶片录的相机控制
前端·javascript
陈_杨43 分钟前
鸿蒙APP开发-带你走进节流战的Canvas图表
前端·javascript