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

相关推荐
我家媳妇儿萌哒哒17 分钟前
el-upload 点击上传按钮前先判断条件满足再弹选择文件框
前端·javascript·vue.js
加油,前进17 分钟前
layui和vue父子级页面及操作
javascript·vue.js·layui
天天向上102418 分钟前
el-tree按照用户勾选的顺序记录节点
前端·javascript·vue.js
sha虫剂21 分钟前
如何用div手写一个富文本编辑器(contenteditable=“true“)
前端·vue.js·typescript
咔咔库奇29 分钟前
深入探索 Vue 3 Fragments:从原理到实战的全方位指南
前端·javascript·vue.js
java_强哥32 分钟前
uniapp实现聊天中的接发消息自动滚动、消息定位和回到底部
javascript·vue.js·uni-app
要加油哦~38 分钟前
vue | vue 插件化机制,全局注册 和 局部注册
前端·javascript·vue.js
猫头虎-前端技术1 小时前
HTML 与 CSS 的布局机制(盒模型、盒子定位、浮动、Flexbox、Grid)问题总结大全
前端·javascript·css·vue.js·react.js·前端框架·html
天蓝色的鱼鱼1 小时前
Vue重复提交防御体系从入门到精通
前端·vue.js
爱上妖精的尾巴1 小时前
3-18 WPS JS宏 颜色设置实例应用(按条件设置单元格颜色)学习笔记
javascript·笔记·学习·excel·wps·js宏·jsa