vue3 中ref和reactive的区别讲解

 更新时间:2022年12月19日 09:49:33   作者:wx60d4764eb475e  
如果在template里使用的是ref类型的数据, 那么Vue会自动帮我们添加.value,如果在template里使用的是reactive类型的数据, 那么Vue不会自动帮我们添加.value,这篇文章主要介绍了vue3 中ref和reactive的区别,需要的朋友可以参考下

1. ref和reactive区别:
    如果在template里使用的是ref类型的数据, 那么Vue会自动帮我们添加.value
    如果在template里使用的是reactive类型的数据, 那么Vue不会自动帮我们添加.value

   2. Vue是如何决定是否需要自动添加.value的
    Vue在解析数据之前, 会自动判断这个数据是否是ref类型的,
    如果是就自动添加.value, 如果不是就不自动添加.value

   3. Vue是如何判断当前的数据是否是ref类型的
    通过当前数据的__v_ref来判断的
    如果有这个私有的属性, 并且取值为true, 那么就代表是一个ref类型的数据

数据是ref类型

<template>
  <div>
    <p>{{ age }}</p>
    <button @click="Fn">按钮</button>
  </div>
</template>
 
<script>
import { ref } from "vue";
export default {
  name: "App",
  setup() {
    // ref类型在底层会自动转换成reactive类型
    // ref(18) -> reactive({value: 18})
    let age = ref(18);
 
    function Fn() {
      age.value = 666;
    console.log(age)
    }
    return { age, Fn };
  },
};
</script>

点击按钮,页面数据变成666了,注意,vue模板中没有age.value,因为ref类型的数据有isRef属性,底层自动会将.value加上

 数据是reactive类型

<template>
  <div>
    <p>{{age}}</p>
    <button @click="Fn">按钮</button>
  </div>
</template>
 
<script>
 
import {reactive} from 'vue';
 
export default {
  name: 'App',
  setup() {
    let age = reactive({value: 18});
    function Fn() {
        age.value = 666;
   console.log(age)
    }
    return {age, Fn}
  }
}
</script>

点击按钮,页面还是个对象数据,因为是reactive类型数据,没有isRef属性,vue不会自动在模板添加.value, 所以我们需要手动在模板添加age.value

我们如何判断数据到底是ref还是reactive?

  通过isRef / isReactive 方法

<template>
  <div>
    <p>{{age}}</p>
    <button @click="Fn">按钮</button>
  </div>
</template>
 
<script>
 
  import {reactive} from 'vue';
 
export default {
  name: 'App',
  setup() {
    let age = reactive({value: 18});
    function Fn() {
       console.log(isRef(age)); //false
        console.log(isReactive(age));  //true
        age.value = 666;
    }
    return {age, Fn}
  }
}
</script>

扩展知识点:vue3 中 reactive 和 ref 对比区别

定于数据角度对比:ref 用来定义:基本类型数据
reactive 用来定义:对象、或数组类型的数据
备注:ref也可以用来定义对象或数组类型数据,它内部会自动通过 reactive 转为代理对象

原理角度对比:ref 通过 Object.defineProperty() 的 get 与 set 来实现响应式的(数据劫持)
reactive 通过使用 Proxy 来实现响应式(数据劫持),并通过Reflect 操作源对象内部的数据。

使用角度对比:ref 定义的数据:操作数据需要 .value,读取数据时模版中直接读取不需要 .valuereactive 定义的数据:操作数据与读取数据,均不需要 .value

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

相关文章

  • vue router 用户登陆功能的实例代码

    vue router 用户登陆功能的实例代码

    这篇文章主要介绍了vue router 用户登陆功能的实例代码,主要用到H5中的会话存储(sessionStorage)、vue-router路由前置操作、路由元信息(meta)等知识点,本文通过实例代码给大家介绍的非常详细,需要的朋友可以参考下
    2019-04-04
  • Vue中localStorage的用法和监听localStorage值的变化

    Vue中localStorage的用法和监听localStorage值的变化

    这篇文章主要介绍了Vue中localStorage的用法和监听localStorage值的变化,本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下
    2023-04-04
  • Element中select多数据加载优化的实现

    Element中select多数据加载优化的实现

    本文主要介绍了Element中select多数据加载优化的实现,文中通过示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2021-09-09
  • 基于vue实现图片预览功能并显示在弹窗的最上方

    基于vue实现图片预览功能并显示在弹窗的最上方

    这篇文章主要为大家详细介绍了如何基于vue实现图片预览功能并显示在弹窗的最上方,感兴趣的小伙伴可以跟随小编一起学习一下
    2024-10-10
  • vue 按钮 权限控制介绍

    vue 按钮 权限控制介绍

    这篇文章主要介绍了vue 按钮 权限控制,在日常项目中,会碰到需要根据后台接口返回的数据,来判断当前用户的操作权限,必须当有删除权限时,就显示删除按钮,下面我们就来了解一下具体的解决方法,需要的朋友也可以参考一下
    2021-12-12
  • vue.js+element-ui动态配置菜单的实例

    vue.js+element-ui动态配置菜单的实例

    今天小编就为大家分享一篇vue.js+element-ui动态配置菜单的实例,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧
    2018-09-09
  • vue实现购物车功能(商品分类)

    vue实现购物车功能(商品分类)

    这篇文章主要为大家详细介绍了vue实现购物车功能,商品分类,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2020-04-04
  • 教你如何通过Vue路由改变地址栏的参数

    教你如何通过Vue路由改变地址栏的参数

    Vue是一款非常流行的JavaScript框架,它提供了许多方便开发者的功能,本文将介绍如何通过Vue路由改变地址栏的参数,感兴趣的朋友跟随小编一起看看吧
    2023-10-10
  • Vue之Watcher源码解析(1)

    Vue之Watcher源码解析(1)

    这篇文章主要为大家详细介绍了Vue源码之Watcher的基础知识,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2017-07-07
  • vue实现按钮的长按功能

    vue实现按钮的长按功能

    这篇文章主要介绍了vue实现按钮的长按功能,点击按钮实现长按,用户需要按下按钮几秒钟,然后触发相应的事件,本文通过实例代码给大家分享实现思路,感兴趣的朋友一起看看吧
    2022-01-01

最新评论