vue中的ref/reactive区别及原理

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是对整个对象进行响应式化处理。

相关推荐
长空任鸟飞_阿康3 小时前
RAG 文档摄入全链路,从原理到生产落地
vue.js·人工智能·python
沐土Arvin3 小时前
中国省市区json数据
前端
Sweet锦3 小时前
Vue3 集成 ApexCharts 避坑指南:从动画失效到自定义指令的完美解决方案
vue·echarts
星空3 小时前
Node.js (Express) + Vue2 Axios 前后端交互 CRUD
vue.js·node.js·express
狗哥哥3 小时前
统一下载网关技术方案
前端·架构
三块可乐两块冰3 小时前
rag学习5
linux·前端·python
铁皮饭盒3 小时前
Bun + SQLite 10个实用技巧
前端·javascript·后端
Hooray3 小时前
告别低效循环!AI Agent 编排+编程显示器,让前端开发效率实现断代式跃升
前端·人工智能·ai编程
飞天狗1113 小时前
零基础JavaWeb入门——第4课:表单处理 —— 浏览器怎么把数据发给服务器
java·开发语言·前端·后端·servlet
Hooray4 小时前
前端暗黑模式的适配艺术
前端·vue.js·视觉设计