Vue3中ref和reactive的基本使用及区别详析

 更新时间:2022年07月15日 14:32:15   作者:北海的大鱼  
这篇文章主要给大家介绍了关于Vue3中ref和reactive的基本使用及区别的相关资料,需要的朋友可以参考下

前言

今天给大家讲一下在vue3中ref和reactive的使用方法,以及他们的使用区别在哪里,下面通过一个简单的计数器的例子来给大家进行说明

ref—计数器案例

ref 主要用于基本类型的响应,看如下代码:

import { ref } from 'vue' // 导入ref
interface DataProps {
  count: number;
  double: number;
  increase: () => void
}
export default {
  name: 'App',
  setup() {
    const count = ref(0)
    const double = computed(() => {
      return count.value*2
    })
    const increase = () => {
      count.value++
    }
    
    return {
      count,
      double,
      increase
    }
  }
}

在setup方法通过ref实现响应式对象,最后要在return中进行返回。

我们发现几个变量都分散在各处,那么有没有什么办法可以将他们包裹在对象里呢?那就来看看下面的reactive

reactive—计数器案例

reactive:主要用于引用类型的响应。里面属性拿出来单独使用,可能会丧失响应性

代码如下(示例):

import { reactive, toRefs } from 'vue'
interface DataProps {
  count: number;
  double: number;
  increase: () => void
}
export default {
  name: 'App',
  setup() {
    const data: DataProps = reactive({
      count: 0,
      increase: () => { data.count++ },
      double: computed(() => data.count * 2)
    })
    const refData = toRefs(data)
    refData.double
    return {
      ...refData
    }
  }
}

定义一个data对象,在里面定义参数

在return中我们需要让变量保持响应式,那么就需要使用toRefs,就可以将普通的类型变为ref响应式类型

PS:在return里面使用…refData(前面加三点),那么在使用的时候就可以直接使用变量名,例如:< h1> {{count}} < /h1>

区别

通过上面的例子,大家应该对ref和reactive有了一些了解,下面通过标准的 js 来进行类比,帮助大家更好的理解区别:

类似使用ref

先定义x,y为0,当使用函数时,再更新x和y的值

let x = 0
let y = 0

function updataNumber() {
    x = 2
    y = 3 
}

类似使用 reactive

在pos中有两个key都为0,在函数中更新两个值pos.x = 2.

x,y必须和对象在一起才能引用,如果像第三种const { x } = pos,先取出来,再进行更新,x还是旧的值,并且会丧失响应式

const pos = {
    x: 0,
    y: 0,
}

function updata    Object() {
    pos.x = 2
    pos.y = 3 
}

const { x } = pos
pos.x = 3

附:ref和reative的使用心得

一般来说,vue定义响应式变量有两种写法:

1)写法1:reative声明所有变量,最后return的时候一起toRefs

一种是把reative当做vue2的data,所有变量用reative一次性生成,最后一起toRefs(这个注意不要漏)。优点是赋值不用写.value

 <template>
  <h2>name: {{state.name}}</h2>
  <h2>age: {{state.age}}</h2>
  <h2>wife: {{state.wife}}</h2>
  <hr>
  <button @click="update">更新</button>
</template>
 
<script>
/* 
reactive: 
    作用: 定义多个数据的响应式
    const proxy = reactive(obj): 接收一个普通对象然后返回该普通对象的响应式代理器对象
    响应式转换是“深层的”:会影响对象内部所有嵌套的属性
    内部基于 ES6 的 Proxy 实现,通过代理对象操作源对象内部数据都是响应式的
*/
import {
  reactive,toRefs
} from 'vue'
export default {
  setup () {
    /* 
    定义响应式数据对象
    */
    const state = reactive({
      name: 'tom',
      age: 25,
      wife: {
        name: 'marry',
        age: 22
      },
    })
    console.log(state, state.wife)
 
    const update = () => {
      state.name += '--'
      state.age += 1
      state.wife.name += '++'
      state.wife.age += 2
    }
 
    return {
      ...toRefs(state)
    }
  }
}
</script>

2)写法2:从头到尾都用ref声明变量,赋值的时候要注意加.value

第二种,从头到尾都用ref,除了赋值时要.value很麻烦,其他倒没什么。

<template>
  <h2>{{count}}</h2>
  <hr>
  <button @click="update">更新</button>
</template>
 
<script>
import {
  ref
} from 'vue'
export default {
 
  setup () {
 
    // 定义响应式数据 ref对象
    const count = ref(1)
    console.log(count)
 
    // 更新响应式数据的函数
    function update () {
      // alert('update')
      count.value = count.value + 1
    }
 
    return {
      count,
      update
    }
  }
}
</script>

总结

通过例子和js原生例子类比给大家讲了ref和reactive的使用及区别。在实际项目中,大家还是需要根据自己平时的编程习惯来选择对应的方法。

到此这篇关于Vue3中ref和reactive的基本使用及区别的文章就介绍到这了,更多相关Vue3 ref和reactive使用内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

相关文章

  • 在Vue组件中使用 TypeScript的方法

    在Vue组件中使用 TypeScript的方法

    typescript不仅可以约束我们的编码习惯,还能起到注释的作用,当我们看到一函数后我们立马就能知道这个函数的用法。这篇文章主要介绍了在Vue组件中使用 TypeScript的方法,需要的朋友可以参考下
    2018-02-02
  • vue-cli浏览器实现热更新的步骤

    vue-cli浏览器实现热更新的步骤

    这篇文章主要介绍了vue-cli-浏览器实现热更新,最常用的是webpack-dev-server,它是一个小型的Node.js Express服务器,它使用webpack-dev-middleware来服务于webpack的包,本文结合实例代码介绍的非常详细,需要的朋友参考下吧
    2024-03-03
  • vue2中filter()的实现代码

    vue2中filter()的实现代码

    vue2.0里,不再有自带的过滤器,需要自己定义过滤器。下面通过实例代码给大家介绍vue2中filter()的相关知识,感兴趣的朋友一起看看吧
    2017-07-07
  • Vue.js 事件修饰符的使用教程

    Vue.js 事件修饰符的使用教程

    在实际开发中,不可避免的会使用到对于事件的操作,如何处理 DOM 事件流,成为我们必须要掌握的技能。这篇文章主要介绍了Vue.js 事件修饰符的使用教程,需要的朋友可以参考下
    2018-11-11
  • Vue中splice()方法对数组进行增删改等操作的实现

    Vue中splice()方法对数组进行增删改等操作的实现

    vue中对数组的元素进行删除,以前一直以为这个方法是vue中特有的,后来百度之后才知道原来是js的一个写法,下面这篇文章主要给大家介绍了关于Vue中splice()方法对数组进行增删改等操作的实现方法,需要的朋友可以参考下
    2023-05-05
  • 10个Vue3中的编程实用技巧分享

    10个Vue3中的编程实用技巧分享

    这篇文章主要为大家详细介绍了10个Vue3中的编程实用技巧,文中的示例代码讲解详细,具有一定的借鉴价值,感兴趣的小伙伴可以跟随小编一起学习一下
    2025-03-03
  • vue3+vite使用环境变量.env的一些配置情况详细说明

    vue3+vite使用环境变量.env的一些配置情况详细说明

    开发中经常会使用环境变量,Vite相比于Webpack也有一定的变化,下面这篇文章主要给大家介绍了关于vue3+vite使用环境变量.env的一些配置情况说明的相关资料,需要的朋友可以参考下
    2022-12-12
  • Vue 配置代理详情

    Vue 配置代理详情

    这篇文章主要介绍了Vue 配置代理详情,文章围绕主题的相关资料展开详细内容介绍,具有一定的参考价值,需要的小伙伴可以参考一下,希望对你的学习有所帮助
    2022-04-04
  • 详解从Vue-router到html5的pushState

    详解从Vue-router到html5的pushState

    这篇文章主要介绍了详解从Vue-router到html5的pushState,小编觉得挺不错的,现在分享给大家,也给大家做个参考。一起跟随小编过来看看吧
    2018-07-07
  • vue(2.x,3.0)配置跨域代理

    vue(2.x,3.0)配置跨域代理

    这篇文章主要介绍了vue(2.x,3.0)配置跨域代理,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2019-11-11

最新评论