vue与react的对比

1、原理

vue:

Object.defineProperty或Object.proxy 数据劫持,监听数据变化,通过渲染函数编译模板,形成虚拟dom,setter,getter更新dom

react:虚拟dom的差异比较,来最小化实际的dom更新次数,从而提高应用的性能和效率

2、编程风格和视图风格

vue:html模板

react:jsx

3、组件、路由、状态管理

vue 复合式Api,vue-router,vuex/pinia

react 类组件或函数式组件,react-router,redux/zustand/mobx

4、响应式、生命周期、副作用

vue new Proxy(),beforeCreate/created()/beforeMount/mounted/beforeUpdate/updated()/beforeDestory/destoryed,watchEffect((cb)=>{cb(()=>{})})

react state管理,constructor/componentDidMount/componentDidUpdate/componentWillUnmount,

useEffect(()=>{return ()=>{}})

5、基础用法对比

5.1 模板对比

vue 指令 + 模板

react js + 模板
5.2 样式对比

vue class,style

react className
5.3 事件对比

vue 事件比较丰富

react onChange
5.4 表单对比

vue 双向绑定v-model

react 表单受控与非受控

受控组件和非受控组件最大的区别在于组件的值是由React状态控制还是Dom节点控制
5.5 通信对比
父子

vue props parent children

react props 子组件调用父组件的函数并传值
跨级

vue provide/inject a t t r s / attrs/ attrs/listeners

react context
兄弟

vue eventBus

react 子A -> 父 父 -> 子B
任意组件

mitt

5.6 逻辑复用

vue use函数自定义的钩子函数

react use函数自定义的钩子函数

5.7 内容分发

vue 插槽slot

react props.children

5.8 dom操作

vue: ref

react: ref

相关推荐
zhangyao9403308 小时前
开发pc端时,表格的高度怎么设置才能铺满页面
前端·javascript·elementui
XinZong9 小时前
实测OpenClaw虾淘:全民工具AI时代,冷门非工具类的Skill还能出圈吗?
javascript
烛衔溟9 小时前
TypeScript 类的类型 —— 作为类型使用
javascript·ubuntu·typescript
之歆9 小时前
Day16_JavaScript 轮播图与事件工程实战(下篇)
服务器·开发语言·前端·javascript·网络·性能优化
kyriewen10 小时前
我关掉了Copilot:因为我写的代码出现在了别人的建议里
前端·javascript·ai编程
SmartRadio11 小时前
STM32WLE5 LoRa Smart TDMA 完整协议栈实现(工程级可直接编译)-【1】
javascript·stm32·单片机·嵌入式硬件·lora·自组网·smart tdma
竹林81811 小时前
用 wagmi v2 踩坑两天,我终于搞懂了多链钱包切换
前端·javascript
吃乔巴的糖11 小时前
Vue 3 打印模板设计器 (print-canvas-designer)
前端·vue.js
子云zy11 小时前
JS 对象与包装类:new 做了什么?字符串为什么有 length?
前端·javascript
茶底世界之下13 小时前
你的 Mac 里,藏着一支 AI 开发团队
前端·javascript