首页 > 其他分享 >ref、reactive、toRef、toRefs使用与区别

ref、reactive、toRef、toRefs使用与区别

时间:2022-10-09 13:44:29浏览次数:47  
标签:响应 对象 toRefs toRef reactive ref

  • reactive

    • 传参:reactive(arg),arg只能是对象
      • arg为普通对象
    • 返回响应式对象,不管层级多深,都能响应
    • 使用:获取数据值的时候直接获取,不需要加.value
    • 特点:解构、扩展运算符会失去响应式($1)
  • ref

    • 传参:ref(arg)
      • arg为任意类型,推荐基本类型使用
    • 参数可以传递任意数据类型,传递对象类型时也能保持深度响应式,所以适用性更广
    • 使用:获取数据值的时候需要加.value。
    • vue 3.0 setup里定义数据时推荐优先使用ref,方便逻辑拆分和业务解耦。

      

  • toRef

    • 针对reactive中$1的问题,创建了toRef。toRef 用于源响应式对象上的属性新建一个ref,从而保持对其源对象属性的响应式连接。

    • 传参:toRef(arg1, arg2)

      • 参数1:arg1 - reactive响应式对象
      • 参数2:arg2 - 该响应对象中的某个属性。
    • 返回:一个ref数据可以针对reactive创建的响应式对象中的某个属性创建一个ref,且两个之间保持引用关系。

      也就是说用一个对象的某个属性,可以通过两个方式来改变,结果是一致的,都反应到了该响应式对象上来。

     使用:1、获取数据值的时候需要加.value。2、场景:使用父组件传递的props数据时,要引用props的某个属性且要保持响应式连接时就很有用。      特点:、toRef后的ref数据如果是复杂类型数据时,不是原始数据的拷贝,而是引用,改变结果数据的值也会同时改变原始数据。

  • toRefs

  • 从名字上可以看出跟toRef是相似的,其实确实也是相似的
  • 区别
    • toRef是将reactive中的某个属性转为ref
    • toRefs是一次性将reactive中的所有属性都转为ref
  • 传参:toRefs(arg1)
    • 只接受一个参数,为reactive响应式对象
  • 对于reactive中存在的$1问题,toRefs返回的响应式对象可以进行解构、扩展运算符等操作,而不会失去响应式。
  • 使用:获取数据值的时候需要加.value
  • 特点:toRefs后的ref数据如果是复杂类型数据时,不是原始数据的拷贝,而是引用,改变结果数据的值也会同时改变原始数据

五、结语

尽量不要混着用,reactive 和 ref 选一种,toRef 和 toRefs 选一种,不然代码会很乱。

推荐 ref 和 toRefs 一把梭。




标签:响应,对象,toRefs,toRef,reactive,ref
From: https://www.cnblogs.com/the-big-dipper/p/16771850.html

相关文章

  • #yyds干货盘点#Vue3的reactive
    最近一阶段在学习Vue3,Vue3中用 ​​reactive​​、​​ref​​ 等方法将数据转化为响应式数据,在获取时使用 ​​track​​ 往 ​​effect​​ 中收集依赖,在值改变时,使......
  • 高级vue 组合api setup toRefs 用法
    <script>import{ref,reactive,toRefs}from'vue'exportdefault{  setup(){   letdata=reactive({    mes:0,    userObj:{   ......
  • 高级vue 组合api setup reactive用法
    <script>import{reactive}from'vue'exportdefault{  setup(){   letdata=reactive({    mes:0   });   constadd=()=>{ ......
  • vue3 ref()和reactive()的
    vue3中对响应式数据的声明官方给出了ref()和reactive()这两种方式,今天我们来聊聊两种定义定义数据方式有什么不同如上代码,我们使用变量声明的方式,ref的方式,reactive......
  • vue3 的 ref、isRef、toRef、toRefs、toRaw 详细介绍
    ref、isRef、toRef、toRefs、toRaw看着一堆类似的东西,一个头两个大,今天整理一篇文章详细介绍它们的功能及区别。1、refref属性除了能够获取元素外,也可以使用ref函数,创建......
  • Vue3 reactive和ref响应式问题
    reactive:一般用来接收复杂类型数据。定义后再取出就不是响应式数据了,这个问题解决方法如下:reactive接收钩子函数(遇到的是生命周期函数onMounted钩子函数)中axios请求的数据......
  • Spring Security 介绍中的 servlet 和 reactive
    最近在看看SpringSecurity中的内容。看到了下面一段话,还挺拗口的。SpringSecurity提供了一个验证(authentication),授权(authorization),和保护常见攻击的框架。Sprin......
  • vue3 的 ref、isRef、toRef、toRefs、toRaw 详细介绍
    ref、isRef、toRef、toRefs、toRaw看着一堆类似的东西,一个头两个大,今天整理一篇文章详细介绍它们的功能及区别。1、refref属性除了能够获取元素外,也可以使用ref函数,......
  • 【vue3】reactive不能直接赋值的解决方法
    在vue3里,ref和reacitve都可以定义响应式数据,但是两者有所不同。在使用reactive定义复杂结构的响应式数据时,如果你要对其赋值,会丢失其响应性。然后赋值是我们经常进行的操作......
  • Vue3:响应式 API-工具函数 isRef()、unref()、toRef()、toRefs()、readonly()
     isRef()检查某个值是否为ref。<scriptsetup>import{ref,isRef}from"vue"letmsg=ref(0)functionfn(){console.log(isRef(msg))//判断是否为响应性变量......