数据驱动视图 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 靠状态不可变 + 显式更新
相关推荐
kyriewen26 分钟前
用了半年 Claude Code 后,我尝试关掉它写了一周代码——结果比想象中严重
前端·javascript·ai编程
山河木马2 小时前
矩阵专题0-webGL中的矩阵
javascript·webgl·计算机图形学
徐小夕2 小时前
万字拆解 JitWord:企业级实时协同文档底层架构 + 大模型 AI 融合完整实践
前端·vue.js·github
Asize3 小时前
多模态生图:从 Vite 工程化到前端调用 Qwen Image
javascript·人工智能·后端
陳陈陳3 小时前
从Token到Embedding:一篇文章搞懂大模型的「文字数学变形记」
前端·javascript·ai编程
用户938515635073 小时前
从 O(n²) 到 O(nlogn):一文读懂快速排序的“快”与“妙”
javascript·算法
橘子星3 小时前
LLM 无状态架构实践:从原理到代码落地
前端·javascript·人工智能
用户83134859306983 小时前
Cesium实现雾气效果:按钮一键控制打开/关闭雾气效果,滑块拖动实时控制雾气浓度
vue.js·cesium
To_OC4 小时前
手写快排次次翻车?别死背快排模板了,这才是面试官想听的底层逻辑
javascript·算法·排序算法
风止何安啊5 小时前
网课倍速痛点解决:一套前端代码实现自由控速播放器
前端·javascript·node.js