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;
相关推荐
IT_陈寒21 分钟前
Vue 3.4 正式发布:5个不可错过的性能优化与Composition API新特性
前端·人工智能·后端
N***738528 分钟前
前端无障碍开发资源,WCAG指南与工具
前端
Cocktail_py1 小时前
JS如何调用wasm
开发语言·javascript·wasm
我有一棵树1 小时前
深入理解html 加载、解析、渲染和 DOMContentLoaded、onload事件
前端·性能优化·html
JIngJaneIL1 小时前
就业|高校就业|基于ssm+vue的高校就业信息系统的设计与实现(源码+数据库+文档)
java·前端·数据库·vue.js·spring boot·毕设·高校就业
一 乐1 小时前
社区互助|社区交易|基于springboot+vue的社区互助交易系统(源码+数据库+文档)
java·数据库·vue.js·spring boot·后端·小区互助系统
G***T6911 小时前
前端构建工具环境变量,安全管理
前端
Want5952 小时前
HTML礼物圣诞树
前端·html
REDcker2 小时前
Cursor Chrome DevTools MCP 配置指南 for Windows
前端·windows·chrome devtools
张可爱2 小时前
20251115复盘记录:让分页乖乖“坐好”+ 卡片统一渐变描边与圆角
前端