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;
相关推荐
渐儿几秒前
React Native 实操开发文档
前端
Nturmoils1 分钟前
书签真正难的不是收藏,而是找回来:我是怎么做这个 Chrome 插件的
javascript·后端·浏览器
HYCS2 分钟前
用pixijs实现fabricjs(三):对象继承链和自定义对象
前端·javascript·canvas
biubiubiu_LYQ2 分钟前
萌新小白基础篇之JS预编译
javascript
渐儿2 分钟前
Electron 实操开发文档
前端
小则又沐风a4 分钟前
深入了解进程概念 第二章
java·linux·服务器·前端
亲亲小宝宝鸭4 分钟前
微前端方案探索:qiankun
前端·微服务
渐儿5 分钟前
跨端框架实操开发文档:Electron / Tauri / React Native
前端
ZC跨境爬虫8 分钟前
跟着 MDN 学 HTML day_60:(表单与按钮技能测试实战)
服务器·前端·javascript·数据库·ui·html
lihaozecq9 分钟前
做 Agent SDK 必须支持的插件能力:8 个钩子搞定横切关注点
前端·agent·ai编程