vue与react的对比

本文对比了Vue和React在数据劫持、虚拟DOM、编程风格、组件与状态管理、响应式特性、DOM操作等方面的关键特性和用法,以及它们在基础用法上的差异,帮助开发者理解和选择适合的框架。
摘要由CSDN通过智能技术生成

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

  • 7
    点赞
  • 11
    收藏
    觉得还不错? 一键收藏
  • 2
    评论
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值