前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >Vue3 响应式 API 之 ref 和 reactive

Vue3 响应式 API 之 ref 和 reactive

作者头像
青年码农
发布2022-12-13 18:28:59
8710
发布2022-12-13 18:28:59
举报
文章被收录于专栏:青年码农青年码农

我们知道 ref 函数和 reactive 函数用于实现数据的响应性。但是开发中如何选择使用 ref 和 reactive 呢?下面我们就详细说说 ref 和 reactive 的区别。

回顾

在 Vue3 版本之前,响应数据在 data 函数中定义

代码语言:javascript
复制
<template>
  <h1>{{ title }}</h1>
</template>

<script>
  export default {
    data() {
      return {
        title: "Hello, Vue!"
      };
    }
  };
</script>

Vue2 会遍历 data 中的所有属性,使用 Object.defineProperty 把每个 property 全部转为 getter/setter,getter 用来收集依赖,setter 用来执行 notify,发布更新事件。Vue2 对每个属性创建一个 Dep 对象,作为订阅发布模式的中间机构来收集依赖。Vue 追踪这些依赖,在其被访问和修改时通知变更。

Vue3

Vue3 中引入了 ref,reactive 来创建响应式数据:

代码语言:javascript
复制
<template>
  <h1>{{ title }}</h1>
  <h2>{{ data.author }}</h2>
  <button @click=""changeTitle>修改title</button>
</template>

<script>
  import { ref, reactive, toRefs } from "vue";
  export default {
    setup() {
      const title = ref("Hello, Vue 3!");
      // 修改
      function changeTitle(){
        title.value == "Hello, Vue3!"
      }

      const data = reactive({
        author: "青年码农",
        age: "18"
      });

      return { title, data, changeTitle };
    }
  };
</script>

从上面的代码我们大概可以看出区别。ref 的作用就是将一个原始数据类型转换成一个响应式数据,原始数据类型共有 7 个,分别是:String、Number、BigInt、Boolean、Symbol、Undefined、Null。但是有个奇淫技巧,那就是 ref 也可以是对象。后面我们再说。reactive 的作用就是将一个对象转换成一个响应式对象。

ref

ref 的作用就是将一个原始数据类型转换成一个带有响应式特性的数据类型。

代码语言:javascript
复制
const title = ref("Hello, Vue 3!");

ref 接收参数并将其包裹在一个带有 value 属性的对象中返回,然后可以使用该属性访问或更改响应式变量的值,比如上面的代码我们使用 count.value 去修改值,如下:

代码语言:javascript
复制
title.value = "Hello, Vue3!"

上面提到了 ref 也是可以接受对象类型

代码语言:javascript
复制
const data = ref({
    author: "青年码农",
    age: "18"
});

这种也是可以的,赋值的时候就会有点别扭了。

代码语言:javascript
复制
data.value.author = "nmgwap";

ref 响应式原理是依赖于 Object.defineProperty(),因此如果是对象,还是建议用 reactive。

reactive

reactive 返回对象的响应式副本, 它将解包所有深层的 refs,同时维持 ref 的响应性。一般我们用来实现对象或者数组的响应性。

代码语言:javascript
复制
const data = reactive({
    author: "青年码农",
    age: "18"
});

修改和普通对象没区别,视图会实时更新

代码语言:javascript
复制
data.author = "nmgwap"

总结

ref 是针对原始数据类型 和 reactive 是用于对象 这两个 API 都是为了给 JavaScript 普通的数据类型赋予响应式特性(reactivity)。

本文参与 腾讯云自媒体分享计划,分享自微信公众号。
原始发表:2022-09-05,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 青年码农 微信公众号,前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体分享计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • 回顾
  • Vue3
    • ref
      • reactive
      • 总结
      领券
      问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档