数据驱动视图 vue和react对比

一句话总区别

  • Vue:自动响应式,数据变了自动更视图
  • React:手动触发更新,靠状态不可变驱动重渲染

一、核心原理对比

Vue 数据驱动

Vue 是自动依赖追踪的响应式;

  1. 通过 Proxy(Vue3)劫持对象的 get / set
  2. get 收集依赖(谁用到了这个数据)
  3. set 派发更新(通知用到的地方重新渲染)
  4. 精确知道哪个组件、哪个地方要更新

React 数据驱动

React 本身没有内置响应式系统,它是基于状态不可变和显式更新实现状态驱动。

  1. 没有数据劫持,不监听数据变化
  2. 必须调用 setState / useState 更新函数 手动触发更新
  3. 引用变化判断是否更新(浅比较)
  4. 触发后组件重新 render,再用 diff 算 DOM 差异

二、更新粒度对比

Vue

精准更新

  • 哪个响应式数据变了,就只更新用到它的组件/节点
  • 不需要你手动优化,默认性能就很好

React

组件级更新

  • 一旦 setState整个组件函数重新执行
  • 子组件也会跟着重新 render
  • 需要手动优化:React.memo / useMemo / useCallback

三、写法风格对比

Vue

  • 直接修改数据:this.count++count.value++
  • 写法自然、直观
  • 不需要关心不可变数据

React

  • 必须不可变更新,不能直接改原对象/数组
  • 要:setCount(prev => prev + 1)
  • 对象/数组要展开:setUser({ ...user, name: 'xx' })

四、性能机制对比

Vue

  • 依赖收集 = 精准更新
  • 渲染开销小,默认性能高
  • 大型对象、长列表天然更友好

React

  • 组件级重渲染 = 容易不必要渲染
  • 复杂页面必须手动优化
  • 优化成本比 Vue 高

五、一句话总结(面试必背)

  • Vue 是自动响应式,精准追踪依赖,数据变自动更视图。
  • React 是手动触发更新,基于不可变数据,组件级重渲染。
  • Vue 靠劫持 + 依赖收集 ;React 靠状态不可变 + 显式更新
相关推荐
我命由我123452 小时前
React - React Redux 数据共享、Redux DevTools、React Redux 最终优化
前端·javascript·react.js·前端框架·ecmascript·html5·js
Jinuss2 小时前
源码分析之React中的createContext/useContext详解
前端·javascript·react.js
AnalogElectronic2 小时前
uniapp学习7,美团闪购生鲜蔬菜商家详情页
javascript·学习·uni-app
琪伦的工具库2 小时前
在自动化部署流程中集成视频转GIF:工具选型与参数调优
javascript·自动化·音视频
永远的个初学者2 小时前
一个同时支持 React、Vue、Node、CLI、Vite、Webpack 的图片优化库:rv-image-optimize
vue.js·react.js·webpack
吃不胖爹2 小时前
Flutter 基本架构与使用
javascript·flutter·架构
哈__2 小时前
ReactNative项目OpenHarmony三方库集成实战:react-native-tts 语音播放
javascript·react native·react.js
Jinuss2 小时前
源码分析之React中useCallback和useMemo
前端·javascript·react.js
早點睡3902 小时前
ReactNative项目OpenHarmony三方库集成实战:react-native-background-timer
javascript·react native·react.js