Vue3-03-reactive() 响应式基本使用

reactive() 的简介

复制代码
reactive() 是vue3 中进行响应式状态声明的另一种方式;
但是,它只能声明 【对象类型】的响应式变量,【不支持声明基本数据类型】。

reactive() 与 ref() 一样,都是深度响应式的,即对象嵌套属性发生了改变,页面中都会重新刷新。

reactive() 声明的对象变量,可以直接使用它的属性值,无需像 ref() 一样使用 [.value] 的方式读取变量的值。

reactive()  函数返回的是对象的一个代理对象,这个代理对象可以直接操作属性,且这个代理对象是唯一的,
即 同一个对象 多次调用 reactive() 函数,返回的是同一个代理对象。

reactive() 对象解构之后的属性,不具有响应式。

reactive() 对象的值单独传入函数中作为参数时,不具有响应式。

基本使用案例

html 复制代码
<template>
    <div>
       stu: {{ stu }}
       <br>
       numList : {{ numList }}
    </div>
</template>
    
<script setup lang="ts">

    // 引入 reactive
    import {reactive} from "vue"

    // 声明响应式状态 : 必须是一个对象类型
    const stu = reactive({
        id:'001',
        name:'小明',
        classInfo:{
            classId:1001,
            className:'开心一班',
        }
    })

    const numList = reactive([1,2,3,4])

    // 打印一下 响应式的变量,直接打印,无需使用 【.value】 进行值的获取
    console.log('stu : ',stu)
    console.log('numList : ',numList)

</script>
    
<style scoped>
</style>

reactive() 添加数据类型限制

复制代码
官方提示 :不推荐 给 reactive() 使用泛型的方式进行类型限制!

方式一 : 自动类型推导

复制代码
这也是ts的自有特性,因为 reactive() 是封装对象的,所以,自动类型推导也会推导为一个对象类型。
js 复制代码
	// 会自动推导为 {name:string} 类型
    const job = reactive({name:'程序员'})
    console.log('job',job)

方式二 :显示的标注类型

复制代码
如果想给reactive() 添加类型,笔者比较推荐这种方式,
这样程序代码比较清晰,可维护性更高。

可以通过自己定义 接口的方式,进行类型的标注。
这个就纯纯的是ts的知识点了。
js 复制代码
    // 声明一个接口,作为数据类型规范
    interface Job{
        name:string
    }
    // 显式的指定变量的类型
    const job : Job = reactive({name:'程序员'})
    console.log('job',job)
相关推荐
你说啥名字好呢3 天前
【Vue 渲染流程揭秘】
前端·javascript·vue.js·vue3·源码分析
行走的陀螺仪6 天前
vue3-封装权限按钮组件和自定义指令
前端·vue3·js·自定义指令·权限按钮
麦麦大数据6 天前
F046 新闻推荐可视化大数据系统vue3+flask+neo4j
python·flask·vue3·知识图谱·neo4j·推荐算法
Sheldon一蓑烟雨任平生6 天前
Vue3 高级性能优化
性能优化·vue3·tree-shaking·高级性能优化·首屏加载优化·更新优化·大型虚拟列表
前端.攻城狮7 天前
用fetch-event-source处理流式消息:Vue 3中实现openAI/DeepSeek的实时输出
vue3·流式消息
Sheldon一蓑烟雨任平生8 天前
webpack 从零构建 Vue3
webpack·typescript·vue3·webpack配置·从零构建vue3
saadiya~9 天前
基于 Vue3 封装大华 RTSP 回放视频组件(PlayerControl.js 实现)
前端·vue3·大华视频相机前端播放
软件架构师-叶秋10 天前
Vue3+tyepescript+ElementPlus+Axios前端技术栈
前端·vue3·elementplus
一只小阿乐10 天前
vue3封装alert 提示组件 仿element-plus
前端·javascript·vue.js·vue3
Sheldon一蓑烟雨任平生11 天前
Vue3 KeepAlive(缓存组件实例)
vue.js·vue3·组件缓存·keepalive·缓存组件实例·onactivated·ondeactivated