reactive 和ref区别和原理

reactive 和ref区别和原理

在 Vue 3 中,reactive 和 ref 都是用来创建响应式数据的方法。它们的主要区别在于如何使用它们以及它们如何处理值.

reactive 是用来创建响应式对象的。当你传递一个普通的 JavaScript 对象给 reactive,它会返回一个新的响应式对象,这个对象与原始对象具有相同的属性和值,但是当这些属性被修改时,Vue 会自动跟踪这些更改并更新视图。

javascript 复制代码
import { reactive } from 'vue';

const state = reactive({
  count: 0
});

state.count++; // 视图会自动更新

ref 是用来创建响应式单个值的。当你传递一个值给 ref,它会返回一个具有单个属性 .value 的响应式对象,你可以通过这个属性来获取或设置值。

javascript 复制代码
import { ref } from 'vue';

const count = ref(0);

count.value++; // 视图会自动更新

在模板中,Vue 会自动解包 ref 的值,所以你可以直接使用 count 而不是 count.value。

原理方面,reactive 和 ref 都使用了 JavaScript 的 Proxy 对象来实现数据的响应式。当你访问或修改响应式对象的属性时,Proxy 会拦截这些操作并通知 Vue 进行相应的处理。

javascript 复制代码
export declare function reactive<T extends object>(target: T): UnwrapNestedRefs<T>;

export declare type UnwrapNestedRefs<T> = T extends Ref ? T : UnwrapRefSimple<T>;

declare type UnwrapRefSimple<T> = T extends Function | CollectionTypes | BaseTypes | Ref | RefUnwrapBailTypes[keyof RefUnwrapBailTypes] | {
    [RawSymbol]?: true;
} ? T : T extends ReadonlyArray<any> ? {
    [K in keyof T]: UnwrapRefSimple<T[K]>;
} : T extends object & {
    [ShallowReactiveMarker]?: never;
} ? {
    [P in keyof T]: P extends symbol ? T[P] : UnwrapRef<T[P]>;
} : T;
相关推荐
幸运小圣3 分钟前
全面解析 Web 核心性能指标:LCP、INP、CLS 是什么、怎么用、怎么看
前端
如果超人不会飞8 分钟前
TinyRobot SuggestionPopover智能建议弹出框组件
前端·vue.js
LiuJun2Son24 分钟前
Angular 快速入门:从零搭建你的第一个应用
前端·javascript·angular.js
烬羽24 分钟前
从零理解树与二叉树:用 JS 带你手撕遍历和递归
javascript·数据结构
小徐_233331 分钟前
Wot UI 2.1.0 发布:ConfigProvider 全局配置能力升级
前端·uni-app
方白羽32 分钟前
Vibe Coding 四个核心阶段
android·前端·app
奶油话梅糖33 分钟前
浏览器解析 HTML 头部的底层逻辑:从字节流到资源调度
前端·html
YHL33 分钟前
🚀从零理解树与二叉树 —— 概念、实现与遍历
前端·javascript·数据结构
小时前端34 分钟前
微前端技术选型深度分析:从概念到实践
前端
十九画生35 分钟前
学 JavaScript 数据类型,真正要搞懂的是:变量里存的到底是什么?
javascript