vue中的ref/reactive区别及原理

news/2024/7/10 0:49:37 标签: vue.js, javascript, 前端, vue

Vue中的ref和reactive是两种不同的数据响应式管理方式。

ref是Vue 3中新加入的特性,它可以将一个普通的JavaScript对象转换为响应式对象。通过ref创建的响应式对象在访问和修改时会自动触发重新渲染。ref返回的是一个包含value属性的对象,访问或修改数据时需要通过value属性进行操作。

javascript">import { ref } from 'vue';

const count = ref(0);

// 访问响应式数据
console.log(count.value);

// 修改响应式数据
count.value++;

// ref对象仍然是一个对象
console.log(count); // { value: 1 }

reactive是Vue 2中的一个API,它可以将一个普通的JavaScript对象转换为响应式对象。通过reactive创建的响应式对象被称为响应式数据。访问和修改响应式数据时,Vue会跟踪数据的变化并触发视图的更新。

javascript">import { reactive } from 'vue';

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

// 访问响应式数据
console.log(state.count);

// 修改响应式数据
state.count++;

// state对象仍然是一个对象
console.log(state); // { count: 1 }

原理上,ref和reactive都是通过Proxy实现的。当访问响应式对象的属性时,Vue会使用Proxy拦截访问操作,并将该属性标记为依赖,当属性被修改时,Vue会触发相应的更新操作。ref和reactive的区别在于ref是对对象的包装,而reactive是对整个对象进行响应式化处理。


http://www.niftyadmin.cn/n/5398400.html

相关文章

linux使用scp命令来在两台Linux设备之间传输文件

1、linux怎么将一个文件发送到另一个linux设备特定目录下 可以使用scp命令(secure copy)来将文件从一个Linux设备复制到另一个Linux设备的特定目录下。假设你要将本地文件localfile.txt发送到远程设备的/remote/directory目录下,你可以使用以…

Qt篇——QTableWidget选中多行右键删除

效果如图: 代码如下: 头文件中: QTableWidgetItem *selectedItem; //表格被选中的一行 QMenu* originDataTableContextMenu; //表格右键菜单 QAction* originDataTableActionDel; //表格右键菜单…

算法-动态规划(背包)

NO.1 01背包问题 题目: 有 N 件物品和一个容量是 V的背包。每件物品只能使用一次。 第 i 件物品的体积是 vi,价值是 wi。 求解将哪些物品装入背包,可使这些物品的总体积不超过背包容量,且总价值最大。 输出最大价值。 输入格式 第…

SpringBoot动态读取nacos配置(配置热更新)

在微服务架构中,配置的动态更新对于应用的灵活性和可维护性至关重要。Spring Cloud 提供了一种机制,即RefreshScope注解,用于实现配置的热更新。本文将介绍配置热更新的原理以及RefreshScope的作用。 配置热更新原理 配置热更新的原理基于 …

【外设篇】-显示器

显示屏是一种电光转换工具,现在市面上的显示器都是LCD(Liquid Crystal Display,液晶显示器) 显示器参数介绍 对比度 是指画面黑与白的比值,对比度越高能使色彩表现越丰富,对比度越高,显示器的…

VPX基于全国产飞腾FT-2000+/64核+复旦微FPGA的计算刀片

6U VPX计算板 产品简介 产品特点 飞腾计算平台,国产化率100% VPX-MPU6902是一款基于飞腾FT-2000/64核的计算刀片,主频2.2GHz,负责业务数据流的管控和调度。搭配自带独立显示芯片的飞腾X100芯片,可用于于各类终端及服务器类应用场…

Mybatis-plus自定义模板生成代码

Mybatis-plus自定义模板生成代码 参考: 自定义ID生成器 | MyBatis-Plus 自定义属性注入到模板 - MyBatis Plus 教程 MyBatis Plus 代码生成器(最新版本:V3.5.3)使用指南 - 掘金 mybatis plus generator 3.5.1 从了解到自定义…

linux下查看某个命令在哪里个安装包程序下,以ifconfig命令举例子

yum list | grep net-tools (查看yum安装列表中有没有安装指定的软件工具)