vue和react的区别有哪些,要学哪个好

2022-12-08 0 898

vue和react的区别有哪些,要学哪个好

vue和react有什么差别呢?上面从这4个视角而言讹传!

(1)从程式设计本体论的视角讲

在vue-loader、vue-template-compiler的全力支持下,vue能选用SFC单文件组织的方式同时实现组件化;vue有命令,选用命令能够方便快捷地图形快照,vue配置文件是单向存取的;vue模块是如前所述快捷键式的程式设计,常见快捷键有合作开发周期、排序优点、侦听器等;vue的模块库十分经济繁荣,自订优点、自订该事件、自订连接埠是vue模块化的五大此基础。为数众多街道社区中的vue车轮,在vue构架中被Vue.use注册登记方可选用。

react的句法此基础是JSX,react中没有命令,原素图形、条件图形、条目图形、静态式样都是如前所述JSX语法的。在webpack自然环境中,要加装@babel/core、@babel/preset-react等,同时实现对JSX的校对。React配置文件是单向存取的,所推荐选用大列佩季哈区配置文件。模块PCB能是类模块,也能表达式式模块,其中props是React模块化的核心理念。

(2)从模块通讯的视角讲

在vue模块通讯中,跨模块通讯的方式非常丰富且灵巧,常见的通讯计划有兄弟二人模块通讯、ref通讯、该事件汇流排、provide/inject、parent/children、listeners/attrs、slot连接埠通讯等。除此以外,在vue中还能选用vuex 或 mobx 来同时实现跨模块通讯。整体上而言,vue的模块通讯极为灵巧,由上而下、自上而下都是难同时实现的;也便是因为过分灵巧,这会“驱使”合作开发人员难误用通讯方式,引致vue项目呈现“易合作开发、难保护”的现况。

在react中统计数据是单向报文,在模块根上统计数据根本无法由上而下地递送和传达。state是模块Chhatarpur的状况统计数据,props是父级模块传达回来的统计数据。在react中东齐县基本的通讯计划是状况提高,还有React语句也能同时实现由上而下的报文。有鉴于react这种报文的优点,即使集成了Redux仍然会呈现单向报文的特征,因此React报文更难被管理,配合Redux一起更适合做中大型的项目合作开发。

(3)从底层原理的视角讲

vue全力支持命令是因为背后有vue-template-compiler这个校对器的全力支持,把带有命令的快照模板转化成AST抽象句法树,进一步转化成虚拟DOM。vue的响应式原理是选用了 Object.defineProperty 进行了统计数据劫持,统计数据劫持发生vue模块的创建阶段,vue的响应式原理和mobx状况管理的响应式原理相似,这种响应式同时实现最早出现在 knockout 框架。如果要手写一个简单版本的vue,需要同时实现Compiler类(用于模板校对)、Watcher类(用于更新快照)、Dep类(用于依赖收集)、Observer类(用于统计数据劫持)、Vue类(构造表达式)等。

react自v16以后发生了很多变化,v16以后底层的“虚拟DOM”不再是简单JSON统计数据了,React选用了最新的Fiber(单向链表)的统计数据结构,作为“协调”(Diff)运算的此基础统计数据。React背后还提供了强大的 react-reconciler 和 scheduler 库同时实现Fiber链表的生成、协调与调度。相比vue模块,react在较大模块方面的性能更高。如果要手写一个简易版本的React,其核心理念要同时实现以下功能,createElement(用于创建原素)、createDOM/updateDOM(用于创建和更新DOM)、render/workLoop(用于生成Fiber和协调运算)、commitWork(用于提交)等,如果还有全力支持Hooks,还得封闭Hooks相关的方法。

(4)从街道社区发展和未来展望的视角讲

vue生态经济繁荣,用户此基础大。vue3.0和vite的诞生给vue生态增加了新的生命力,同时也给vue合作开发人员带来了空前的挑战。vue3.0为数众多新优点,以组合API、更友好地全力支持TS为代表,使得vue3.0的写法更加灵巧。上手vue3.0并不难,但,要想写出健壮的可保护性更强的vue3.0代码,并不难,这需要广大的前端合作开发人员有更强大的前端此基础功,对MVVM有深刻的理解和沉淀。

react生态稳步向前,背后有强大的Facebook合作开发团队,从类模块程式设计向Hooks程式设计的转化指明了前进的方向。React(v18)呼之欲出,让前端合作开发人员对React更具信心。在国内,阿里系的React开源项目经济繁荣,给以合作开发人员足够的信心,至少三五年内深耕React仍然大有可为。

大家如果还有更好的答案,能在评论区留言。欢迎关注千锋教育,会持续分享更多前端干货!

举报/反馈

相关文章

发表评论
暂无评论
官方客服团队

为您解决烦忧 - 24小时在线 专业服务