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

相关推荐
goDeep12 小时前
useMemo 和 useCallback 的区别,我终于搞懂了
前端
小亮学前端12 小时前
在1Panel中部署Nuxt项目
前端·vue.js
产品研究员12 小时前
AI生成可用的React交互代码实测:Lovable vs Stitch vs Paico
前端·react.js·aigc
labixiong12 小时前
Prompt 工程:当一段文字学会了思考、行动与统治
前端·ai编程
用户8417948145612 小时前
vxe-table 虚拟滚动下自定义行高:支持每行独立高度与自适应
vue.js
biubiubiu_LYQ12 小时前
入门开发者必学篇之JS事件循环:为什么你的代码输出总翻车?
前端·javascript
HwJack2013 小时前
鸿蒙背景下 Cocos Creator 的三大 JS 引擎:JIT 与热更新的十字路口
javascript·华为·harmonyos
程序员黑豆13 小时前
AI全栈开发之Java:怎么安装JDK
前端·ai编程·全栈
周杰伦fans13 小时前
AutoCAD C# 二次开发:如何精确监听工作空间切换事件
前端·c#
丷丩13 小时前
MapLibre GL JS第41课:向地图添加图标
前端·javascript·mapbox·maplibre gl js