Vue和React对比

Vue和React两个JavaScript框架都是当下比较受欢迎的,下面我们来一起探讨下它们的异同和技术选型。

1. 相同点

  • 1.1 都使用了虚拟Dom

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

    在HTML中的标签
    HTML中div

    在JavaScript中,虚拟Dom可以用对象简单地创造一个针对上面例子的映射
    在JavaScript中的映射

    当新一项被加进去这个JavaScript对象时,一个函数会计算新旧Virtual DOM之间的差异并反应在真实的DOM上。

    计算差异的算法是高性能框架的秘密所在,React和Vue在实现上有点不同。

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

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

  • 1.2 组件化

    React与Vue都鼓励组件化应用。这本质上说,是建议你将你的应用分拆成一个个功能明确的模块,每个模块之间可以通过合适的方式互相联系。

    下面我们看一个简单组件的例子

//  Vue例子
<template>
 <div class="content">
   <img :src="item.icon" :alt="item.alt"/>
   <div>
     <p class="header">{{item.name || ''}}</p>
     <p>{{item.des || ''}}</p>
   </div>
 </div>
</template>
<script>
export default {
 name: "test-item",
 props: {
   "item": {
     type: Object,
     default: {}
   },
 }
}
</script>
<style scoped>
 .content {
   width: 100%;
   padding: 8px;
   display: flex;
   justify-content: flex-start;
   text-align: left;
 }
 .content img {
   height: 20px;
   width: 20px;
   margin: auto 8px auto 0;
 }
 .content .header {
   font-weight: bolder;
 }
</style>
//  React
import React from "react";

class TestItem extends React.Component {

    render() {
        const { item } = this.props;

        return (
              <div className="content">
                <img src={item.icon} alt={item.alt} />
                <div>
                  <p className="header">{item.name || ''}</p>
                  <p>{item.des || ''}</p>
                </div>
              </div>
        );
    }
}
export default TestItem;
  • 1.3 Chrome 开发工具
    React和Vue都有很好的Chrome扩展工具去帮助你找出bug。它们会检查你的应用,让你看到Vue或者React中的变化。你也可以看到应用中的状态,并实时看到更新
    React的开发工具react-devtools
    Vue的开发工具vue-devtools
  • 1.4 构建工具
    React和Vue都有自己的构建工具,你可以使用它快速搭建开发环境。React可以使用Create React App,而Vue对应的则是vue-cli。两个工具都能让你得到一个根据最佳实践设置的项目模板
  • 1.5 配套框架

    Vue与React最后一个相似但略有不同之处是它们配套框架的处理方法。相同之处在于,两个框架都专注于UI层,其他的功能如路由、状态管理等都交由其他框架进行处理。

    而不同之处是在于它们如何关联它们各自的配套框架。Vue的核心团队维护着vue-router和vuex,它们都是作为官方推荐的存在。而React的react-router、dva和react-redux则是由社区成员维护。

2. 不同点

Vue与React有很多的相似之处,但他们也有完全不一致的地方。

  • 2.1 JSX和模板
    React与Vue最大的不同就是一个使用JSX语法编写(React), 一个使用模板编写(Vue)
    Vue鼓励你去使用HTML模板去进行渲染, 因此,通过把原有的模板整合成新的Vue模板,Vue很容易提供旧的应用的升级。这也让新来者很容易适应它的语法。
    <test-item
         v-for="(item, index) in data" 
         :item="item" 
         :index="index"
         :key="index"
         :clickHandle="testItemClick(item)" />
    
    而React推荐JSX书写。同样的效果,用JSX书写的如下:
    data.map((item, index) => {
       const itemProps = {
           item, 
           index, 
           key: index, 
           clickHandle: this.testItemClick.bind(this)
        };
        return <TestItem {...itemProps}  />
    })
    
    看起来JSX有些比较麻烦, 但是使用起来比较灵活
    与React一样,Vue在技术上也支持render函数和JSX,但只是不是默认的而已。我们来看下Vue官方的一个例子
    import AnchoredHeading from './AnchoredHeading.vue'
    new Vue({
        el: '#demo',
        render: function (h) {
            return (
                <AnchoredHeading level={1}>
                    <span>Hello</span> world!
                </AnchoredHeading>
            )
          }
    })
    
  • 2.2 状态管理(React)和对象属性(Vue)
    React通过状态(state)进行管理, 并且state对象在React应用中是不可变的在React中你需要使用setState()方法去更新状态
    testItemClick (item) {
        const data = [...this.state.data];
        item.count += 1;
        this.setState({ data })
    }
    
    而在Vue中, 数据由data属性在Vue对象中进行管理。
    testItemClick (item) {
        const items = [...this.items];
        item.count += 1;
        this.items = items;
    }
    
  • 2.3 React Native 和 Weex
    React Native能在手机上创建原生应用,React在这方面处于领先位置。使用JavaScript, CSS和HTML创建原生移动应用, 并且有丰富的官方组件。Vue社区与阿里合作开发Vue版的React Native——Weex也很不错,但仍处于开发状态并且官方组件并不是太丰富。

3. 技术选型

对比完React和Vue的一些特点后, 我们来探讨下在项目中到底该选择那种框架

  • 3.1 编码风格
    如果你喜欢使用JSX,React更加适合; 如果你喜欢使用模板,Vue更加适合;
  • 3.2 性能测试

    下面是性能对比
    运行速度
    内存占用

    这些性能测试显示,Vue 比 React 占用的内存更少,运行速度更快

  • 3.3 大型应用程序

用Vue和React实现的简单应用程序来比较两者,可能会让一个开发者从一开始就更倾向于Vue。这是因为基于模板的应用程序乍看上去更易理解,而且能很快地写好并跑起来。但是这些最初的便利会引入技术债并阻碍应用扩展到更大的规模。模板容易出现难以注意到的运行时错误,同时也不易于测试,重构和分解。
相比之下,Javascript模板可以组织成经过良好分解,且使用避免重复代码原则的代码组件,因而具有更强的可重用性和可测试性。Vue也有组件系统和渲染函数,但React的渲染系统可配置性更强,并包含如shallow rendering这样的特性,可结合React的测试工具一起使用,从而大为提高代码的可测试性及可维护性。

  • 3.4 React更加适合原生应用
    React Native是一个用于通过Javascript构建移动端原生应用程序的库。 它与React.js相同,只是不使用Web组件,而是使用原生组件。
    // JS
    import React, { Component } from 'react'; 
    import { AppRegistry, Text, View } from 'react-native';
    class HelloWorld extends Component {   
      render() {     
        return (       
          <View>         
            <Text>Hello, React Native!</Text>
          </View>
        );   
      }
    }
    AppRegistry.registerComponent('HelloWorld', () => HelloWorld);
    我们只需要一套知识和工具就能开发Web应用和移动端原生应用。
    
    

阿里的Weex也是一个跨平台UI项目,目前它以Vue为灵感,使用了许多相同的语法。但是目前还不够成熟。

  • 3.5 生态圈

    就目前来说, React比Vue要受欢迎许多
    React
    Vue

    这两个框架都是开源的,但是React诞生于Facebook,它的开发者和Facebook都承诺会持续维护React。而Vue则是由独立开发者尤雨溪创造,目前也只有他一名全职维护者。虽然也有一些公司资助Vue,但是规模和Facebook没得比。但是在Github上Vue(122K)获得星数超过了React(117K)

最后, 到底是选择React和Vue, 个人感觉要看开发团队的技术栈, 如果喜欢使用jsx建议用React, 如果喜欢使用模板建议使用Vue; 如果做原生APP, 建议使用ReactNative

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 204,732评论 6 478
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 87,496评论 2 381
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 151,264评论 0 338
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 54,807评论 1 277
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 63,806评论 5 368
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 48,675评论 1 281
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 38,029评论 3 399
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 36,683评论 0 258
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 41,704评论 1 299
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 35,666评论 2 321
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 37,773评论 1 332
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 33,413评论 4 321
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 39,016评论 3 307
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 29,978评论 0 19
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 31,204评论 1 260
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 45,083评论 2 350
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 42,503评论 2 343

推荐阅读更多精彩内容

  • Vue也已经升级到2.0版本了,到现在为止(2016/11/19)比较流行的MVVM框架有AngularJS(也有...
    彬_仔阅读 27,205评论 12 114
  • 最近在逛各大网站,论坛,以及像SegmentFault等编程问答社区,发现Vue.js异常火爆,重复性的提问和内容...
    忘川慕白阅读 5,910评论 7 113
  • 拉锯战持续今天终于完结。 他说我的我都接受了———怨气太深。 是谁让我如花的年纪变成怨妇? 是我自己?是他?终究是...
    央篱阅读 129评论 0 0
  • 当你千辛万苦写完 sci 论文,等着修改对应杂志参考文献格式发表文章时,endnote 却在这个时候掉链子,没有你...
    清水咸鱼阅读 19,588评论 3 15
  • 2015平安走到圣诞 花莲到台东 行驶在中央山脉,两边绿意浓浓,野花很多。 大巴拉长了距离,却看到了曾经在高铁所错...
    wen_a阅读 180评论 0 1