一、框架简介

React主张是函数式编程的理念, 实现了前端界面的高性能高效率开发,react很擅长处理组件化的页面。React的官方网站提到了“学习一次,随处写作”这个关键功能,可以使用React框架在JavaScript中构建移动应用程序。在 React 中,所有的组件的渲染功能都依靠 JSX,它是JavaScript的语法扩展,它在创建UI组件和调试时非常简单有用。

Vue是渐进式JavaScript框架。“渐进式框架”和“自底向上增量开发的设计”是Vue开发的两个概念。

Vue可以在任意其他类型的项目中使用,使用成本较低,更灵活,主张较弱,在Vue的项目中也可以轻松融汇其他的技术来开发。

特点:易用(使用成本低),灵活(生态系统完善,适用于任何规模的项目),高效(体积小,优化好,性能好)。

二、相同点

都有组件化思想

都支持服务器端渲染

都有Virtual DOM(虚拟dom)

数据驱动视图

  • 都有支持native的方案:Vue的weex、React的React native
  • 都有自己的构建工具:Vue的vue-cli、React的Create React App

三、区别

数据流向的不同。react从诞生开始就推崇单向数据流,而Vue是双向数据流

数据变化的实现原理不同。react使用的是不可变数据,而Vue使用的是可变的数据

组件化通信的不同。react中我们通过使用回调函数来进行通信的,而Vue中子组件向父组件传递消息有两种方式:事件和回调函数

diff算法不同。react主要使用diff队列保存需要更新哪些DOM,得到patch树,再统一操作批量更新DOM。Vue 使用双向指针,边对比,边更新DOM

四、适用场景

使用Vue的场景

1.希望用模板搭建应用。因为Vue.js 使用了基于 HTML 的模板语法

2.希望搭建快速的应用。Vue中是双向数据绑定的,无需手动改值。

3.希望应用运行速度快或是尽快能的小。渲染速度高于React,大小小于React

使用React的场景

1.构建大型项目时。因为React有更强的测试性,以及可维护性

2.同时构建Web端和App时。因为React Native与React.js大体相同。

3.创建一个更受欢迎的项目。React较于Vue在国际上使用更广泛。

五、总结

Vue的优势包括

  • 模板和渲染函数的弹性选择, 简单的语法及项目创建, 更快的渲染速度和更小的体积;

React的优势包括

  • 更适用于大型应用和更好的可测试性,同时适用于Web端和原生App,更大的生态圈带来的更多支持和工具 。

而实际上,React和Vue都是非常优秀的框架,它们之间的相似之处多过不同之处,并且它们大部分最棒的功能是相通的。

如果想将降低学习成本或前端JavaScript框架集成到现有应用程序中,Vue是更好的选择,如果想构建大型应用项目或者使用JavaScript构建移动应用程序,React绝对是最好的选择。

以上为个人经验,希望能给大家一个参考,也希望大家多多支持阿兔在线工具。

点赞(0)

微信公众账号

微信扫一扫加关注

发表
评论
返回
顶部