一、框架简介
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绝对是最好的选择。
以上为个人经验,希望能给大家一个参考,也希望大家多多支持编程网。