0

0

Vue3中reactive函数能否使基础数据类型保持响应式?

心靈之曲

心靈之曲

发布时间:2025-03-06 08:46:12

|

1067人浏览过

|

来源于php中文网

原创

Vue3中reactive函数能否使基础数据类型保持响应式?

vue3 的 reactive 函数能否让基础数据类型(如数字)保持响应式?答案是否定的。

在 Vue3 中,使用 reactiveref 创建响应式变量时,传入基础数据类型(例如数字)虽然界面数值可能看似更新,但 reactive 本身并不会使其响应式。这是 Vue3 响应式系统的设计机制决定的。

文章开头的问题中,示例代码用 reactiveref 分别创建了两个变量,初始值均为数字 1。控制台会警告“value cannot be made reactive: 1”,但界面数值仍会随定时器变化而更新。这并非因为 reactive 对数字 1 进行了响应式处理,而是因为 ref 创建的响应式变量的存在。

根据 Vue3 源码,reactive 只能代理对象,无法直接追踪基础数据类型的变化。示例代码中,ref 创建的变量 msgRef 是一个响应式对象。Vue3 的依赖收集机制基于组件,渲染函数会收集 msgRef 作为依赖。当 msgRef 更新时,触发依赖更新,渲染函数重新执行。此时,reactive 创建的变量 msgReactive 的更新并非由自身响应式机制驱动,而是渲染函数重新执行的被动更新。可以理解为 msgReactive “搭便车”更新了。因此,msgReactive 的更新并非真正的响应式更新,而是渲染函数重新执行的副产物。

移除 ref 创建的变量后,reactive 创建的变量将不再更新,因为不再有响应式对象触发依赖更新和渲染函数重新执行。

蛙蛙写作——超级AI智能写作助手
蛙蛙写作——超级AI智能写作助手

蛙蛙写作辅助AI写文,帮助获取创意灵感,提供拆书、小说转剧本、视频生成等功能,是一款功能全面的AI智能写作工具。

下载

立即学习前端免费学习笔记(深入)”;

总结:reactive 本身无法使基础数据类型具有响应式能力,需要借助对象或其他响应式变量才能间接实现界面更新。

相关专题

更多
数据类型有哪几种
数据类型有哪几种

数据类型有整型、浮点型、字符型、字符串型、布尔型、数组、结构体和枚举等。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

299

2023.10.31

php数据类型
php数据类型

本专题整合了php数据类型相关内容,阅读专题下面的文章了解更多详细内容。

220

2025.10.31

vue2.0和3.0区别
vue2.0和3.0区别

vue2.0和3.0区别:vue2的响应式原理是利⽤“Object.defineProperty()”对数据进⾏劫持结合发布订阅模式的⽅式来实现,vue3中使⽤了es6的proxy API对数据代理,实现对数据的监控。本专题为大家提供vue2.0和3.0区别的相关的文章、下载、课程内容,供大家免费下载体验。

153

2023.07.17

vue3的生命周期有哪些
vue3的生命周期有哪些

vue3的生命周期:1、beforecreate;2、created;3、beforemount;4、mounted;5、beforeupdate;6、updated;7、beforedestroy;8、destroyed;9、activated;10、deactivated等等。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

8356

2024.02.23

java学习网站推荐汇总
java学习网站推荐汇总

本专题整合了java学习网站相关内容,阅读专题下面的文章了解更多详细内容。

6

2026.01.08

java学习网站汇总
java学习网站汇总

本专题整合了java学习网站相关内容,阅读专题下面的文章了解更多详细内容。

0

2026.01.08

正则表达式 删除
正则表达式 删除

本专题整合了正则表达式删除教程大全,阅读专题下面的文章了解更多详细教程。

20

2026.01.08

java 元空间 永久代
java 元空间 永久代

本专题整合了java中元空间和永久代的区别,阅读专题下面的文章了解更多详细内容。

3

2026.01.08

java 永久代和元空间
java 永久代和元空间

本专题整合了java中元空间和永久代的区别,阅读专题下面的文章了解更多详细内容。

0

2026.01.08

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
Vue 教程
Vue 教程

共42课时 | 6.1万人学习

Vue3.x 工具篇--十天技能课堂
Vue3.x 工具篇--十天技能课堂

共26课时 | 1.4万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号