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

相关推荐
竹林8181 分钟前
从“后端验证”到“前端签名”:我在Web3项目中重构用户身份认证的实战记录
前端·javascript
农夫山泉不太甜2 分钟前
Expo开发App实战指南:从技术选型到架构设计
前端
进击的尘埃2 分钟前
Vite 插件开发入门:从零写一个自动生成路由的插件
javascript
高桥凉介发量惊人3 分钟前
状态管理与架构篇-异步状态管理:加载、空态、错误态统一处理
前端
清汤饺子3 分钟前
搞懂 Cursor 后,我一行代码都不敲了《进阶篇》
前端·javascript·后端
诗句藏于尽头4 分钟前
MacBook上的Safari安装油猴插件
前端·safari
哟哟耶耶6 分钟前
vue3-<script setup>是Vue3.2+引入编译语法糖与编译器宏以及useSlots()和useAttrs()
前端·javascript·vue.js
后端不背锅6 分钟前
订单超时取消系统:从数据库轮询到延迟队列演进
前端
小彭努力中8 分钟前
195.Vue3 + OpenLayers:监听瓦片地图加载情况(200、403及异常处理)
前端·css·openlayers·cesium·webgis
给钱,谢谢!9 分钟前
记录uni-app Vue3 慎用 Teleport,会导致页面栈混乱
前端·vue.js·uni-app