【譯】Vue和其他前端框架的對比

React

React和Vue有很多相似點咆课,他們都有以下特性:

  • 利用virtual DOM
  • 提供響應(yīng)的可組合的視圖組件
  • 專注于核心庫结闸,路由和全局狀態(tài)管理由與之協(xié)同工作的庫處理

性能概述

在目前為止我們測試過的所有現(xiàn)實場景中,Vue的性能都大幅優(yōu)于React(通常至少快20-50%,甚至有些情況下還要快的多)。

渲染性能#####

在React中慧起,我們假設(shè)渲染一個元素的開銷是1,平均每個組件的開銷是2驯绎。在Vue中完慧,渲染一個元素的開銷可能只有0.1,但由于建立響應(yīng)式系統(tǒng)的必要步驟剩失,平均每個組件可能將是4屈尼。
  在極端情況下,比如使用一個普通的組件去渲染每個元素拴孤,Vue可能會更慢脾歧。然而,Vue和React都提供了函數(shù)式的組件去解決類似的情況演熟。在本文截稿前鞭执,React計劃為函數(shù)式組件提升性能司顿,使他們近似等于所有元素的開銷。Vue的函數(shù)式組件早已進行了這種優(yōu)化兄纺,因此當(dāng)我們使用函數(shù)式組件時大溜,Vue在這種場景下應(yīng)當(dāng)快大約20倍,但是在React優(yōu)化組件之后僅僅快了10倍估脆。

刷新性能#####

在React中钦奋,你需要在各個地方實現(xiàn)shouldComponentUpdate,并使用immutable數(shù)據(jù)結(jié)構(gòu)去實現(xiàn)完全優(yōu)化的重新渲染疙赠。在Vue中付材,一個組件的依賴自動被追蹤,因此它僅僅在其中一個依賴改變的時候才刷新圃阳。有時候有一種唯一有用的優(yōu)化措施就是給長列表的每一項添加key屬性厌衔。
  這意味著在同樣未被優(yōu)化的情況下,Vue中的刷新性能事實上比React更好捍岳。由于在Vue中被優(yōu)化的渲染性能富寿,甚至即使React在優(yōu)化之后通常也會比Vue更慢。

開發(fā)#####

顯而易見锣夹,生產(chǎn)環(huán)境中性能是最重要的作喘,這也是我們到此為止正在討論的。性能在開發(fā)中依然舉足輕重晕城。Vue和React在大多數(shù)應(yīng)用的開發(fā)中都足夠的快。
  然而窖贤,如果你正在編寫一些高性能數(shù)據(jù)可視化或者動畫砖顷,你可能發(fā)現(xiàn)一些Vue不能處理超過10fps的場景,這在開發(fā)中很有幫助赃梧。而React甚至調(diào)低至1fps滤蝠。
  這是React大量不變的檢測造成的,這種檢測可能有助于React提供許多有用的警告和錯誤信息授嘀。我們認同這些在Vue中同樣重要物咳,但是當(dāng)我們實現(xiàn)這些檢測的同時嘗試去保持性能。

HTML&CSS#####

在React中蹄皱,一切都是JavaScript览闰。如果不深究的話,你會感覺它簡潔而優(yōu)雅巷折。不幸的事實是压鉴,在JavaScript中再造HTML和CSS會造成很多困擾。在Vue中锻拘,我們完全擁抱web技術(shù)并構(gòu)造于之上油吭。為了向大家說明這句話的意思击蹲,我們將舉幾個例子。

  • JSX vs Templates
    在React中婉宰,所有的組件在render函數(shù)中使用JSX(一種用JavaScript寫的申明式的類XML的語法)來描述UI歌豺,舉個例子:
render () {
 let { items } = this.props

  let children
  if (items.length > 0) {
    children = (
      <ul>
         {items.map(item =>
           <li key={item.id}>{item.name}</li>
          )}
      </ul>
    )
  } else {
    children = <p>No items found.</p>
  }

  return (
    <div className='list-container'>
      {children}
    </div>
  )
}

在Vue中,我們也提供了render函數(shù)心包,甚至也支持JSX类咧,因為JSX這種支持完全編程的特性有時會有用,雖然我們通常并不推薦在組件中使用render函數(shù)谴咸。
作為替代轮听,我們提供了templates:

<template>
 <div class="list-container">
  <ul v-if="items.length">
   <li v-for="item in items">
    {{ item.name }}
   </li>
  </ul>
  <p v-else>No items found.</p>
 </div>
</template>

以下是使用template的好處:

  • 寫模板對于我們在書寫風(fēng)格上無需多做改變
  • 模板總是申明式的
  • 一些合法的HTML語法在模板中也可用
  • 讀起來更像英文(比如 for each item in items)
  • JavaScript代碼可讀性更好

使用模板不僅讓開發(fā)者寫起來更容易,而且設(shè)計師和經(jīng)驗尚淺的開發(fā)者也會發(fā)現(xiàn)分析岭佳、貢獻代碼更簡單血巍。
  不止如此,通過使用HTML珊随,Vue允許你在模板匯總使用諸如Pug(原名Jade)之類的預(yù)處理器述寡。
  React生態(tài)系統(tǒng)也有一個項目(react-templates)允許你使用模板,但是這個東西有一些缺陷:

  • 遠沒有Vue的模板系統(tǒng)那么多特性
  • 它要求HTML從組件文件中分離
  • 由于是第三方庫而不是官方支持的叶洞,它可能不會保持和React核心的更新同步
組件內(nèi)CSS#####

未完待續(xù)......


原文地址:http://rc.vuejs.org/guide/comparison.html
作者:尤雨溪(Evan You)
譯者:熊賢仁

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末鲫凶,一起剝皮案震驚了整個濱河市,隨后出現(xiàn)的幾起案子衩辟,更是在濱河造成了極大的恐慌螟炫,老刑警劉巖,帶你破解...
    沈念sama閱讀 216,651評論 6 501
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件艺晴,死亡現(xiàn)場離奇詭異昼钻,居然都是意外死亡,警方通過查閱死者的電腦和手機封寞,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 92,468評論 3 392
  • 文/潘曉璐 我一進店門然评,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人狈究,你說我怎么就攤上這事碗淌。” “怎么了抖锥?”我有些...
    開封第一講書人閱讀 162,931評論 0 353
  • 文/不壞的土叔 我叫張陵亿眠,是天一觀的道長。 經(jīng)常有香客問我宁改,道長缕探,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 58,218評論 1 292
  • 正文 為了忘掉前任还蹲,我火速辦了婚禮爹耗,結(jié)果婚禮上耙考,老公的妹妹穿的比我還像新娘。我一直安慰自己潭兽,他們只是感情好倦始,可當(dāng)我...
    茶點故事閱讀 67,234評論 6 388
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著山卦,像睡著了一般鞋邑。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上账蓉,一...
    開封第一講書人閱讀 51,198評論 1 299
  • 那天枚碗,我揣著相機與錄音,去河邊找鬼铸本。 笑死肮雨,一個胖子當(dāng)著我的面吹牛,可吹牛的內(nèi)容都是我干的箱玷。 我是一名探鬼主播怨规,決...
    沈念sama閱讀 40,084評論 3 418
  • 文/蒼蘭香墨 我猛地睜開眼,長吁一口氣:“原來是場噩夢啊……” “哼锡足!你這毒婦竟也來了波丰?” 一聲冷哼從身側(cè)響起,我...
    開封第一講書人閱讀 38,926評論 0 274
  • 序言:老撾萬榮一對情侶失蹤舶得,失蹤者是張志新(化名)和其女友劉穎掰烟,沒想到半個月后,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體沐批,經(jīng)...
    沈念sama閱讀 45,341評論 1 311
  • 正文 獨居荒郊野嶺守林人離奇死亡媚赖,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點故事閱讀 37,563評論 2 333
  • 正文 我和宋清朗相戀三年,在試婚紗的時候發(fā)現(xiàn)自己被綠了珠插。 大學(xué)時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點故事閱讀 39,731評論 1 348
  • 序言:一個原本活蹦亂跳的男人離奇死亡颖对,死狀恐怖捻撑,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情缤底,我是刑警寧澤顾患,帶...
    沈念sama閱讀 35,430評論 5 343
  • 正文 年R本政府宣布,位于F島的核電站个唧,受9級特大地震影響江解,放射性物質(zhì)發(fā)生泄漏。R本人自食惡果不足惜徙歼,卻給世界環(huán)境...
    茶點故事閱讀 41,036評論 3 326
  • 文/蒙蒙 一犁河、第九天 我趴在偏房一處隱蔽的房頂上張望鳖枕。 院中可真熱鬧,春花似錦桨螺、人聲如沸宾符。這莊子的主人今日做“春日...
    開封第一講書人閱讀 31,676評論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽魏烫。三九已至,卻和暖如春肝箱,著一層夾襖步出監(jiān)牢的瞬間哄褒,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 32,829評論 1 269
  • 我被黑心中介騙來泰國打工煌张, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留呐赡,地道東北人。 一個月前我還...
    沈念sama閱讀 47,743評論 2 368
  • 正文 我出身青樓唱矛,卻偏偏與公主長得像罚舱,于是被迫代替她去往敵國和親。 傳聞我的和親對象是個殘疾皇子绎谦,可洞房花燭夜當(dāng)晚...
    茶點故事閱讀 44,629評論 2 354

推薦閱讀更多精彩內(nèi)容