Vue3 中为什么需要 ref?

大家好,我是哈默。今天我们来说一下为什么在 Vue3 中我们需要 ref

reactive 的使用

我们知道,在使用 reactive 的时候,我们可以给 reactive 传入对象:

js 复制代码
<script setup>
import { reactive } from "vue";

const info = reactive({
  name: "hamo",
  age: 20,
});
</script>

此时,运行正常。

给 reactive 传入原始类型的数据

但如果我们给 reactive 传入原始类型的数据:

js 复制代码
<script setup>
import { reactive } from "vue";

const name = reactive("hamo");
</script>

这个时候,就会报错:

js 复制代码
⚠ value cannot be made reactive: hamo

报错的原因

以上报错的原因是因为,reactive 内部是用 Proxy 实现的:

Proxy 的语法是这样子的:

js 复制代码
// obj 被代理对象
const obj = {
  name: "hamo",
  age: 20,
};

// proxyObj 代理对象
// obj 被代理对象
const proxyObj = new Proxy(obj, {
  set() {
    // 触发依赖
    console.log("触发了 set,设置了值");
  },
  get() {
    // 收集依赖
    console.log("触发了 get,读取了值");
  },
});

也就是说,我们在 new Proxy 的时候,第一个参数,obj,被代理对象,它只能够传引用类型,如果我们传原始类型,就会报错:

而我们的 reactive 它又是基于 Proxy 的,也就是说,reactive 的第一个参数,也只能传递 引用类型,无法处理 原始类型,所以就报错了。

ref 可以接收原始类型

ref 的第一个参数,是可以接收 原始类型 的,因为 ref 并不是由 Proxy 实现的,它是一个 RefImpl 类的对象:

而这个 RefImpl 类,第一个参数,是可以接收原始类型的,也可以接收引用类型:

js 复制代码
class RefImpl<T> {
  private _value: T
  ...

  // constructor 的第一个参数 value 可以是原始类型的,也可以是引用类型
  constructor(value: T, public readonly __v_isShallow: boolean) {
    this._rawValue = __v_isShallow ? value : toRaw(value)
    this._value = __v_isShallow ? value : toReactive(value)
  }

  get value() {
    ...
  }

  set value(newVal) {
    ...
  }
}

总结

因为我们存在需要定义 原始类型的响应性数据 的需求,所以我们就需要有 ref 这个东西,来处理 原始类型数据 的响应性。

相关推荐
蟾宫曲1 小时前
在 Vue3 项目中实现计时器组件的使用(Vite+Vue3+Node+npm+Element-plus,附测试代码)
前端·npm·vue3·vite·element-plus·计时器
秋雨凉人心1 小时前
简单发布一个npm包
前端·javascript·webpack·npm·node.js
liuxin334455661 小时前
学籍管理系统:实现教育管理现代化
java·开发语言·前端·数据库·安全
qq13267029401 小时前
运行Zr.Admin项目(前端)
前端·vue2·zradmin前端·zradmin vue·运行zradmin·vue2版本zradmin
魏时烟2 小时前
css文字折行以及双端对齐实现方式
前端·css
2401_882726483 小时前
低代码配置式组态软件-BY组态
前端·物联网·低代码·前端框架·编辑器·web
web130933203983 小时前
ctfshow-web入门-文件包含(web82-web86)条件竞争实现session会话文件包含
前端·github
胡西风_foxww3 小时前
【ES6复习笔记】迭代器(10)
前端·笔记·迭代器·es6·iterator
前端没钱4 小时前
探索 ES6 基础:开启 JavaScript 新篇章
前端·javascript·es6
m0_748255264 小时前
vue3导入excel并解析excel数据渲染到表格中,纯前端实现。
前端·excel