专栏名称: 前端大全
分享 Web 前端相关的技术文章、工具资源、精选课程、热点资讯
目录
相关文章推荐
前端早读课  ·  【早阅】Cursor ... ·  昨天  
桦爸聊升学  ·  考研后闪电留学一站式解读20241224(一) ·  2 天前  
桦爸聊升学  ·  考研后闪电留学一站式解读20241224(一) ·  2 天前  
前端早读课  ·  【早阅】工程团队代码所有权挑战 ·  4 天前  
前端大全  ·  两款知名国产前端开源项目被“投毒” ·  6 天前  
51好读  ›  专栏  ›  前端大全

Vue vs React: Javascript 框架之战

前端大全  · 公众号  · 前端  · 2017-06-29 19:55

正文

(点击上方公众号,可快速关注)

英文:Peter Tasker  译文:众成翻译 

www.zcfy.cc/article/vue-vs-react-battle-of-the-javascript-frameworks-3310.html

如有好文章投稿,请点击 → 这里了解详情


正如我们之前提到的,WordPress 的核心团队正争论着为应该将哪款(前端框架)加入现在的架构之中。目前看来,暂时脱颖而出的是React与Vue.js,社区中的很多成员正权衡着这两款框架的利弊。


那到底哪款框架会胜出,哪款框架又会沦为昔日的prototype.js.呢?让我们一起看看吧。


我已经写出了两个几乎一样的Web应用,一个是基于Vue,另一个则基于React,可以方便你在看这篇文章的时候查找相关代码。


  • React sample app(https://github.com/ptasker/pasta-pete-react)

  • Vue sample app(https://github.com/ptasker/pasta-pete-vue)


简单介绍


除非你最近一直不关注前端的发展,不然你肯定听说过由Facebook创建的JavaScript UI框架——React。它支撑着包括Instagram在内的大多数Facebook网站。React与当时流行的jQuery, Backbone.js和Angular 1等框架不同,它的诞生改变了JavaScript的世界。其中最大的变化是React推广了Virtual DOM(我们稍后探究)并创造了新的语法——JSX,JSX允许开发者在JavaScript中书写HTML(译者注:即HTML in JavaScript)。WAT?


Vue致力解决的问题与React一致,但却提供了另外一套解决方案。Vue使用模板系统而不是JSX,使其对现有应用的升级更加容易。这是因为模板用的就是普通的HTML,通过Vue来整合现有的系统是比较容易的,不需要整体重构。同时Vue声称它更容易学习,我最近才接触Vue,能证明所言非虚。关于Vue还需要说的是,Vue主要是由一位开发者进行维护的,而不像React一样由如Facebook这类大公司维护。


相似之处


React与Vue存在很多相似之处,例如他们都是JavaScript的UI框架,专注于创造前端的富应用。不同于早期的JavaScript框架“功能齐全”,Reat与Vue只有框架的骨架,其他的功能如路由、状态管理等是框架分离的组件。


Virtual DOM


啊哈,人们经常说Virtual DOM是什么呢?



Vue.js(2.0版本)与React的其中最大一个相似之处,就是他们都使用了一种叫’Virtual DOM’的东西。所谓的Virtual DOM基本上说就是它名字的意思:虚拟DOM,DOM树的虚拟表现。它的诞生是基于这么一个概念:改变真实的DOM状态远比改变一个JavaScript对象的花销要大得多。


Virtual DOM是一个映射真实DOM的JavaScript对象,如果需要改变任何元素的状态,那么是先在Virtual DOM上进行改变,而不是直接改变真实的DOM。当有变化产生时,一个新的Virtual DOM对象会被创建并计算新旧Virtual DOM之间的差别。之后这些差别会应用在真实的DOM上。


例子如下,我们可以看看下面这个列表在HTML中的代码是如何写的:


    class="list">

  

  • item 1

      

  • item 2


  • 而在JavaScript中,我们可以用对象简单地创造一个针对上面例子的映射:


    {

        type: 'ul',

        props: {'class': 'list'},

        children: [

            { type: 'li', props: {}, children: ['item 1'] },

            { type: 'li', props: {}, children: ['item 2'] }

        ]

    }


    真实的Virtual DOM会比上面的例子更复杂,但它本质上是一个嵌套着数组的原生对象。


    当新一项被加进去这个JavaScript对象时,一个函数会计算新旧Virtual DOM之间的差异并反应在真实的DOM上。计算差异的算法是高性能框架的秘密所在,React和Vue在实现上有点不同。


    Vue宣称可以更快地计算出Virtual DOM的差异,这是由于它在渲染过程中,会跟踪每一个组件的依赖关系,不需要重新渲染整个组件树。


    而对于React而言,每当应用的状态被改变时,全部子组件都会重新渲染。当然,这可以通过shouldComponentUpdate这个生命周期方法来进行控制,但Vue将此视为默认的优化。


    小结:如果你的应用中,交互复杂,需要处理大量的UI变化,那么使用Virtual DOM是一个好主意。如果你更新元素并不频繁,那么Virtual DOM并不一定适用,性能很可能还不如直接操控DOM。


    组件化


    React与Vue都鼓励组件化应用。这本质上说,是建议你将你的应用分拆成一个个功能明确的模块,每个模块之间可以通过合适的方式互相联系。关于组件化的例子可以在这篇文章的中间部分被找到:


    你可以认为组件就是用户界面中的一小块。如果让我来设计Facebook的UI界面,那么聊天窗口会是一个组件,评论会是另一个组件,不断更新的好友列表也会作为一个组件。

    在Vue中,如果你遵守一定的规则,你可以使用单文件组件.


    //PastaItem.vue