返回顶部
首页 > 资讯 > 前端开发 > JavaScript >Vue3中ref和reactive的基本使用及区别详析
  • 395
分享到

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

2024-04-02 19:04:59 395人浏览 八月长安
摘要

目录前言ref—计数器案例Reactive—计数器案例区别类似使用ref类似使用 reactive附:ref和reative的使用心得总结前言 今天给大家讲一

前言

今天给大家讲一下在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>

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使用内容请搜索编程网以前的文章或继续浏览下面的相关文章希望大家以后多多支持编程网!

--结束END--

本文标题: Vue3中ref和reactive的基本使用及区别详析

本文链接: https://lsjlt.com/news/164347.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

猜你喜欢
  • Vue3中ref和reactive的基本使用及区别详析
    目录前言ref—计数器案例reactive—计数器案例区别类似使用ref类似使用 reactive附:ref和reative的使用心得总结前言 今天给大家讲一...
    99+
    2024-04-02
  • 详解vue3中ref和reactive用法和区别
    vue3中ref和reactive区别 1、前言2、基本用法2.1 ref2.2 reactive 3、ref和reactive定义数组对比3.1 ref定义数组3.1 reactive定义数组 4、ref 和reactiv...
    99+
    2023-08-30
    vue.js javascript ecmascript
  • vue3 中ref和reactive的区别讲解
    1. ref和reactive区别:    如果在template里使用的是ref类型的数据, 那么Vue会自动帮我们添加.value    ...
    99+
    2022-12-19
    vue3 ref和reactive的区别 vue3 ref和reactive vue  ref和reactive的区别
  • vue3 ref和reactive的区别有哪些
    本文小编为大家详细介绍“vue3 ref和reactive的区别有哪些”,内容详细,步骤清晰,细节处理妥当,希望这篇“vue3 ref和reactive的区别有哪些”文章能帮助大家解决疑惑,下面跟着小编的思路慢慢深入,一...
    99+
    2023-07-05
  • Vue3响应式方案及ref reactive的区别详解
    目录一、前言二、新的方案1. 缘由2. Proxy 和 Reflect1) Proxy2) Reflect3. reactive1) createReactiveObject() 函...
    99+
    2022-12-19
    vue3响应式布局 vue3 ref和reactive区别 vue3中ref和reactive
  • 浅谈vue3中ref、toRef、toRefs 和 reactive的区别
    目录一、ref——定义任意类型响应式数据二、reactive——定义响应式对象三、toRef——将一个 rea...
    99+
    2024-04-02
  • 详解Vue3中ref和reactive函数的使用
    目录前言ref 函数介绍ref 函数使用ref 函数处理基本数据类型ref 函数处理复杂数据类型ref 函数获取单个DOM元素其他相关方法reactive 函数介绍reactive ...
    99+
    2024-04-02
  • vue3中ref和reactive怎么使用
    这篇“vue3中ref和reactive怎么使用”文章的知识点大部分人都不太理解,所以小编给大家总结了以下内容,内容详细,步骤清晰,具有一定的借鉴价值,希望大家阅读完这篇文章能有所收获,下面我们一起来看看这篇“vue3中ref和reacti...
    99+
    2023-07-05
  • vue3中如何使用ref和reactive
    这篇文章主要介绍“vue3中如何使用ref和reactive”的相关知识,小编通过实际案例向大家展示操作过程,操作方法简单快捷,实用性强,希望这篇“vue3中如何使用ref和reactive”文章能帮助大家解决问题。1.前言vue3新增了r...
    99+
    2023-07-06
  • Vue3中的ref和reactive怎么使用
    今天小编给大家分享一下Vue3中的ref和reactive怎么使用的相关知识点,内容详细,逻辑清晰,相信大部分人都还太了解这方面的知识,所以分享这篇文章给大家参考一下,希望大家阅读完这篇文章后有所收获,下面我们一起来了解一下吧。一、是什么r...
    99+
    2023-07-06
  • Vue3中的ref和reactive如何使用
    这篇文章主要讲解了“Vue3中的ref和reactive如何使用”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“Vue3中的ref和reactive如何使用”吧!一、是什么ref和reacti...
    99+
    2023-07-06
  • Vue3.0中Ref与Reactive的区别示例详析
    目录Ref与Reactive Ref ReactiveRef与Reactive的区别 shallowRef 与shallowReactive toRaw ---只修改数据不渲染页面 ...
    99+
    2024-04-02
  • 解析vue3的ref,reactive的使用和原理
    目录1.前言2.比较3.ref源码解析4.reactive源码解析createReactiveObjecthandles的组成get陷阱set陷阱5.总结1.前言 vue3新增了re...
    99+
    2024-04-02
  • vue3中如何使用setup、 ref和reactive
    1.初识setUp的使用简单介绍下面的代码功能:使用ref函数,去使用监听某一个变量的变化,并且把它渲染到视图上。setUp函数是组合API的入口函数。这个是非常重要的。setUp可以去监听变量的变化哈!我们将会利用它ref 在vue中内置...
    99+
    2023-05-16
    Vue3 reactive setup
  • vue3中ref和reactive的用法和解析(推荐)
    目录1.前言2.比较3.ref源码解析4.reactive源码解析createReactiveObjecthandles的组成get陷阱set陷阱5.总结1.前言  &nb...
    99+
    2023-03-19
    vue3 ref和reactive用法 vue3 ref和reactive
  • vue3中的ref、reactive怎么使用
    本篇内容主要讲解“vue3中的ref、reactive怎么使用”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“vue3中的ref、reactive怎么使用”吧!reactive()基本用法在 Vu...
    99+
    2023-07-05
  • 怎么在vue3中使用setup、 ref和reactive
    本文小编为大家详细介绍“怎么在vue3中使用setup、 ref和reactive”,内容详细,步骤清晰,细节处理妥当,希望这篇“怎么在vue3中使用setup、 ref和reactive”文章能帮助大家解决疑惑,下面跟着小编的思路慢慢深入...
    99+
    2023-07-06
  • vue3中的ref与reactive如何使用
    本文小编为大家详细介绍“vue3中的ref与reactive如何使用”,内容详细,步骤清晰,细节处理妥当,希望这篇“vue3中的ref与reactive如何使用”文章能帮助大家解决疑惑,下面跟着小编的思路慢慢深入,一起来学习新知识吧。一、r...
    99+
    2023-07-06
  • Vue3中的ref和reactive响应式原理解析
    目录1 ref2 isref判断是不是一个ref对象3 shallowref创建一个跟踪自身.value变化的 ref,但不会使其值也变成响应式的4 triggerRef5 cust...
    99+
    2022-11-13
    Vue3 ref和reactive响应式 Vue3 ref和reactive
  • Vue3中ref与toRef的区别浅析
    1. ref是复制,视图会更新 如果利用ref将某一个对象中的某一个属性值变成响应式数据 我们修改响应式数据是不会影响原始数据的; 同时视图会跟新。 ref就是复制 复制是不会影响原...
    99+
    2024-04-02
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作