vue3,ref和reactive声明变量有什么区别,分别怎么用

vue/vue3,ref和reactive声明变量有什么区别,分别怎么用

适用的变量类型不同

  1. 对于原始类型,即非对象类型,只能用ref
  2. 对于对象类型,既可以用ref,也可以用reactive

在js中获取值的方式不同

  1. 在js中,获取ref声明的变量值,需要通过 .value 获取
  2. 获取react声明的变量值,直接获取即可

侦听深度不同

  1. 如果侦听ref声明的对象类型变量,当变量的属性发生变化时,不触发侦听,需要设置深度侦听{deep:true}
  2. 如果侦听reactive声明的变量,当变量的属性发生变化时,触发侦听,无需设置深度侦听

响应性区别

  1. ref声明的对象类型变量,可以通过 .value直接用新的对象赋值,改变变量的值,变量响应性存在
  2. 给reactive包裹的对象类型变量重新赋值,变量响应性消失,该方法不可取。
  3. reactive包裹的对象可以通过Vue.set()方法来重新赋值
  4. reactive包裹的对象给其属性赋值,是不会影响响应性的
相关推荐
程序员爱钓鱼7 分钟前
Node.js 编程实战:测试与调试 —— 调试技巧与性能分析
前端·后端·node.js
JQLvopkk9 分钟前
Vue框架技术详细介绍及阐述
前端·javascript·vue.js
vyuvyucd10 分钟前
插件式开发:C++与C#实战指南
java·前端·数据库
C_心欲无痕11 分钟前
ts - 类型收窄
前端·typescript
笔COOL创始人15 分钟前
requestAnimationFrame 动画优化实践指南
前端·javascript·面试
sophie旭18 分钟前
性能监控之首屏性能监控小实践
前端·javascript·性能优化
+VX:Fegn089519 分钟前
计算机毕业设计|基于springboot + vue物流配送中心信息化管理系统(源码+数据库+文档)
数据库·vue.js·spring boot·后端·小程序·课程设计
北辰alk21 分钟前
一文解锁vue3中hooks的使用姿势
vue.js
北辰alk22 分钟前
vue3 如何监听路由变化
vue.js