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;
相关推荐
田本初14 分钟前
如何修改npm包
前端·npm·node.js
明辉光焱35 分钟前
[Electron]总结:如何创建Electron+Element Plus的项目
前端·javascript·electron
牧码岛1 小时前
Web前端之汉字排序、sort与localeCompare的介绍、编码顺序与字典顺序的区别
前端·javascript·web·web前端
开心工作室_kaic1 小时前
ssm111基于MVC的舞蹈网站的设计与实现+vue(论文+源码)_kaic
前端·vue.js·mvc
云空1 小时前
《InsCode AI IDE:编程新时代的引领者》
java·javascript·c++·ide·人工智能·python·php
晨曦_子画1 小时前
用于在 .NET 中构建 Web API 的 FastEndpoints 入门
前端·.net
慧都小妮子2 小时前
Spire.PDF for .NET【页面设置】演示:在 PDF 文件中添加图像作为页面背景
前端·pdf·.net·spire.pdf
咔咔库奇2 小时前
ES6基础
前端·javascript·es6
Jiaberrr2 小时前
开启鸿蒙开发之旅:交互——点击事件
前端·华为·交互·harmonyos·鸿蒙