欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

Vue與React的區(qū)別和優(yōu)勢(shì)對(duì)比

 更新時(shí)間:2020年12月18日 09:43:12   作者:lucky_qi  
這篇文章主要介紹了Vue與React的區(qū)別和優(yōu)勢(shì)對(duì)比,幫助大家更好的選擇適合自己的前端框架,迷茫的同學(xué)可以進(jìn)來(lái)參考下

簡(jiǎn)單介紹

React--Facebook創(chuàng)建的JavaScript UI框架。它支撐著包括Instagram在內(nèi)的大多數(shù)Facebook網(wǎng)站。React與當(dāng)時(shí)流行的jQuery,Backbone.js和Angular 1等框架不同,它的誕生改變了JavaScript的世界。其中最大的變化是React推廣了Virtual DOM(虛擬DOM)并創(chuàng)造了新的語(yǔ)法——JSX,JSX允許開(kāi)發(fā)者在JavaScript中書(shū)寫HTML(譯者注:即HTML in JavaScript)。

Vue致力解決的問(wèn)題與React一致,但卻提供了另外一套解決方案。Vue使用模板系統(tǒng)(弱化的jsx),使其對(duì)現(xiàn)有應(yīng)用的升級(jí)更加容易。這是因?yàn)槟0逵玫木褪瞧胀ǖ腍TML,通過(guò)Vue來(lái)整合現(xiàn)有的系統(tǒng)是比較容易的,不需要整體重構(gòu)。同時(shí)Vue的學(xué)習(xí)曲線相對(duì)react來(lái)說(shuō)更加容易。

相似之處

React與Vue有很多相似之處,如他們都是JavaScript的UI框架,專注于創(chuàng)造前端的富應(yīng)用。不同于早期的JavaScript框架“功能齊全”,Reat與Vue只有框架的骨架,其他的功能如路由、狀態(tài)管理等是框架分離的組件。

  • 兩者都是用于創(chuàng)建UI的JavaScript庫(kù);
  • 兩者都快速輕便;
  • 都有基于組件的架構(gòu);
  • 都是用虛擬DOM;
  • 都可放入單個(gè)HTML文件中,或者成為更復(fù)雜webpack設(shè)置中的模塊;
  • 都有獨(dú)立但常用的路由器和狀態(tài)管理庫(kù);

它們之間的最大區(qū)別是Vue通常使用HTML模板文件,而React則完全是JavaScript。Vue有雙向綁定語(yǔ)法糖。

不同點(diǎn)

1.監(jiān)聽(tīng)數(shù)據(jù)變化的實(shí)現(xiàn)原理不同

Vue通過(guò) getter/setter以及一些函數(shù)的劫持,能精確知道數(shù)據(jù)變化。

React默認(rèn)是通過(guò)比較引用的方式(diff)進(jìn)行的,如果不優(yōu)化可能導(dǎo)致大量不必要的VDOM的重新渲染。為什么React不精確監(jiān)聽(tīng)數(shù)據(jù)變化呢?這是因?yàn)閂ue和React設(shè)計(jì)理念上的區(qū)別,Vue使用的是可變數(shù)據(jù),而React更強(qiáng)調(diào)數(shù)據(jù)的不可變,兩者沒(méi)有好壞之分,Vue更加簡(jiǎn)單,而React構(gòu)建大型應(yīng)用的時(shí)候更加魯棒。

2.數(shù)據(jù)流的不同

Vue1.0中可以實(shí)現(xiàn)兩種雙向綁定:父子組件之間,props可以雙向綁定;組件與DOM之間可以通過(guò)v-model雙向綁定。Vue2.x中去掉了第一種,也就是父子組件之間不能雙向綁定了(但是提供了一個(gè)語(yǔ)法糖自動(dòng)幫你通過(guò)事件的方式修改),并且Vue2.x已經(jīng)不鼓勵(lì)組件對(duì)自己的 props進(jìn)行任何修改了。

React一直不支持雙向綁定,提倡的是單向數(shù)據(jù)流,稱之為onChange/setState()模式。不過(guò)由于我們一般都會(huì)用Vuex以及Redux等單向數(shù)據(jù)流的狀態(tài)管理框架。

3.HoC和mixins

Vue組合不同功能的方式是通過(guò)mixin,Vue中組件是一個(gè)被包裝的函數(shù),并不簡(jiǎn)單的就是我們定義組件的時(shí)候傳入的對(duì)象或者函數(shù)。比如我們定義的模板怎么被編譯的?比如聲明的props怎么接收到的?這些都是vue創(chuàng)建組件實(shí)例的時(shí)候隱式干的事。由于vue默默幫我們做了這么多事,所以我們自己如果直接把組件的聲明包裝一下,返回一個(gè)HoC,那么這個(gè)被包裝的組件就無(wú)法正常工作了。

React組合不同功能的方式是通過(guò)HoC(高階組件)。React最早也是使用mixins的,不過(guò)后來(lái)他們覺(jué)得這種方式對(duì)組件侵入太強(qiáng)會(huì)導(dǎo)致很多問(wèn)題,就棄用了mixinx轉(zhuǎn)而使用HoC。高階組件本質(zhì)就是高階函數(shù),React的組件是一個(gè)純粹的函數(shù),所以高階函數(shù)對(duì)React來(lái)說(shuō)非常簡(jiǎn)單。

4.組件通信的區(qū)別

Vue中有三種方式可以實(shí)現(xiàn)組件通信:父組件通過(guò)props向子組件傳遞數(shù)據(jù)或者回調(diào),雖然可以傳遞回調(diào),但是我們一般只傳數(shù)據(jù);子組件通過(guò)事件向父組件發(fā)送消息;通過(guò)V2.2.0中新增的provide/inject來(lái)實(shí)現(xiàn)父組件向子組件注入數(shù)據(jù),可以跨越多個(gè)層級(jí)。

React中也有對(duì)應(yīng)的三種方式:父組件通過(guò)props可以向子組件傳遞數(shù)據(jù)或者回調(diào);可以通過(guò) context 進(jìn)行跨層級(jí)的通信,這其實(shí)和 provide/inject 起到的作用差不多。React 本身并不支持自定義事件,而Vue中子組件向父組件傳遞消息有兩種方式:事件和回調(diào)函數(shù),但Vue更傾向于使用事件。在React中我們都是使用回調(diào)函數(shù)的,這可能是他們二者最大的區(qū)別。

5.模板渲染方式的不同

在表層上,模板的語(yǔ)法不同,React是通過(guò)JSX渲染模板。而Vue是通過(guò)一種拓展的HTML語(yǔ)法進(jìn)行渲染,但其實(shí)這只是表面現(xiàn)象,畢竟React并不必須依賴JSX。

在深層上,模板的原理不同,這才是他們的本質(zhì)區(qū)別:React是在組件JS代碼中,通過(guò)原生JS實(shí)現(xiàn)模板中的常見(jiàn)語(yǔ)法,比如插值,條件,循環(huán)等,都是通過(guò)JS語(yǔ)法實(shí)現(xiàn)的,更加純粹更加原生。而Vue是在和組件JS代碼分離的單獨(dú)的模板中,通過(guò)指令來(lái)實(shí)現(xiàn)的,比如條件語(yǔ)句就需要 v-if 來(lái)實(shí)現(xiàn)對(duì)這一點(diǎn),這樣的做法顯得有些獨(dú)特,會(huì)把HTML弄得很亂。

6.渲染過(guò)程不同

Vue可以更快地計(jì)算出Virtual DOM的差異,這是由于它在渲染過(guò)程中,會(huì)跟蹤每一個(gè)組件的依賴關(guān)系,不需要重新渲染整個(gè)組件樹(shù)。

React在應(yīng)用的狀態(tài)被改變時(shí),全部子組件都會(huì)重新渲染。通過(guò)shouldComponentUpdate這個(gè)生命周期方法可以進(jìn)行控制,但Vue將此視為默認(rèn)的優(yōu)化。

7.框架本質(zhì)不同

Vue本質(zhì)是MVVM框架,由MVC發(fā)展而來(lái);

React是前端組件化框架,由后端組件化發(fā)展而來(lái)。

8.Vuex和Redux的區(qū)別

從表面上來(lái)說(shuō),store注入和使用方式有一些區(qū)別。在Vuex中,store被直接注入到了組件實(shí)例中,因此可以比較靈活的使用:使用dispatch、commit提交更新,通過(guò)mapState或者直接通過(guò)this.store被直接注入到了組件實(shí)例中,因此可以比較靈活的使用:使用dispatch、commit提交更新,通過(guò)mapState或者直接通過(guò)this.store來(lái)讀取數(shù)據(jù)。在Redux中,我們每一個(gè)組件都需要顯示的用connect把需要的props和dispatch連接起來(lái)。另外,Vuex更加靈活一些,組件中既可以dispatch action,也可以commit updates,而Redux中只能進(jìn)行dispatch,不能直接調(diào)用reducer進(jìn)行修改。

從實(shí)現(xiàn)原理上來(lái)說(shuō),最大的區(qū)別是兩點(diǎn):Redux使用的是不可變數(shù)據(jù),而Vuex的數(shù)據(jù)是可變的,因此,Redux每次都是用新state替換舊state,而Vuex是直接修改。Redux在檢測(cè)數(shù)據(jù)變化的時(shí)候,是通過(guò)diff的方式比較差異的,而Vuex其實(shí)和Vue的原理一樣,是通過(guò)getter/setter來(lái)比較的,這兩點(diǎn)的區(qū)別,也是因?yàn)镽eact和Vue的設(shè)計(jì)理念不同。React更偏向于構(gòu)建穩(wěn)定大型的應(yīng)用,非常的科班化。相比之下,Vue更偏向于簡(jiǎn)單迅速的解決問(wèn)題,更靈活,不那么嚴(yán)格遵循條條框框。因此也會(huì)給人一種大型項(xiàng)目用React,小型項(xiàng)目用Vue的感覺(jué)。

總結(jié)

Vue的優(yōu)勢(shì)包括:

  • 模板和渲染函數(shù)的彈性選擇
  • 簡(jiǎn)單的語(yǔ)法及項(xiàng)目創(chuàng)建
  • 更快的渲染速度和更小的體積

React的優(yōu)勢(shì)包括:

  • 更適用于大型應(yīng)用和更好的可測(cè)試性
  • 同時(shí)適用于Web端和原生App
  • 更大的生態(tài)圈帶來(lái)的更多支持和工具

而實(shí)際上,React和Vue都是非常優(yōu)秀的框架,它們之間的相似之處多過(guò)不同之處,并且它們大部分最棒的功能是相通的:

  • 利用虛擬DOM實(shí)現(xiàn)快速渲染
  • 輕量級(jí)
  • 響應(yīng)式組件
  • 服務(wù)器端渲染
  • 易于集成路由工具,打包工具以及狀態(tài)管理工具
  • 優(yōu)秀的支持和社區(qū)

以上就是Vue與React的區(qū)別和優(yōu)勢(shì)對(duì)比的詳細(xì)內(nèi)容,更多關(guān)于Vue與React的資料請(qǐng)關(guān)注腳本之家其它相關(guān)文章!

相關(guān)文章

  • vue中利用iscroll.js解決pc端滾動(dòng)問(wèn)題

    vue中利用iscroll.js解決pc端滾動(dòng)問(wèn)題

    這篇文章主要介紹了vue中利用iscroll.js解決pc端滾動(dòng)問(wèn)題,本文給大家介紹的非常詳細(xì),具有一定的參考借鑒價(jià)值,需要的朋友可以參考下
    2020-02-02
  • vuex頁(yè)面刷新后數(shù)據(jù)丟失的方法

    vuex頁(yè)面刷新后數(shù)據(jù)丟失的方法

    這篇文章主要介紹了vuex頁(yè)面刷新后數(shù)據(jù)丟失的方法,小編覺(jué)得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧
    2019-01-01
  • 大前端代碼重構(gòu)之事件攔截iOS?Flutter?Vue示例分析

    大前端代碼重構(gòu)之事件攔截iOS?Flutter?Vue示例分析

    這篇文章主要為大家介紹了大前端代碼重構(gòu)之事件攔截iOS?Flutter?Vue示例分析,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪
    2023-04-04
  • vue 修改 data 數(shù)據(jù)問(wèn)題并實(shí)時(shí)顯示操作

    vue 修改 data 數(shù)據(jù)問(wèn)題并實(shí)時(shí)顯示操作

    這篇文章主要介紹了vue 修改 data 數(shù)據(jù)問(wèn)題并實(shí)時(shí)顯示操作,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧
    2020-09-09
  • vue中wangEditor的使用及回顯數(shù)據(jù)獲取焦點(diǎn)的方法

    vue中wangEditor的使用及回顯數(shù)據(jù)獲取焦點(diǎn)的方法

    最近在寫vue的項(xiàng)目中,遇到一個(gè)需求,點(diǎn)擊編輯,顯示彈框,在彈框中的富文本編輯器中編輯自定義文本樣式,可以上傳圖片并回顯。接下來(lái)通過(guò)本文給大家介紹vue中wangEditor的使用及回顯數(shù)據(jù)獲取焦點(diǎn)的問(wèn)題,一起看看吧
    2021-09-09
  • Vue實(shí)現(xiàn)Echarts圖表寬高自適應(yīng)的實(shí)踐

    Vue實(shí)現(xiàn)Echarts圖表寬高自適應(yīng)的實(shí)踐

    本文主要介紹了Vue實(shí)現(xiàn)Echarts圖表寬高自適應(yīng)的實(shí)踐,文中通過(guò)示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2021-11-11
  • Vue常用的修飾符的作用詳解

    Vue常用的修飾符的作用詳解

    為了方便大家寫代碼,Vue 給大家提供了很多方便的修飾符,比如我們經(jīng)常用到的取消冒泡,阻止默認(rèn)事件等等,這篇文章將給大家分享Vue 中的常用的修飾符
    2022-08-08
  • Nuxt.js實(shí)現(xiàn)一個(gè)SSR的前端博客的示例代碼

    Nuxt.js實(shí)現(xiàn)一個(gè)SSR的前端博客的示例代碼

    這篇文章主要介紹了Nuxt.js實(shí)現(xiàn)一個(gè)SSR的前端博客的示例代碼,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧
    2019-09-09
  • Uniapp設(shè)置頁(yè)面的背景圖片方法代碼

    Uniapp設(shè)置頁(yè)面的背景圖片方法代碼

    這篇文章主要給大家介紹了關(guān)于Uniapp設(shè)置頁(yè)面的背景圖片,uni-app中設(shè)置背景圖有兩種方式,分別是全局設(shè)置和在相應(yīng)的view內(nèi)設(shè)置背景,文中給出了代碼示例,需要的朋友可以參考下
    2024-03-03
  • Vue學(xué)習(xí)之Vuex的使用詳解

    Vue學(xué)習(xí)之Vuex的使用詳解

    這篇文章主要介紹了Vue中的插件:Vuex。本文將圍繞它的優(yōu)缺點(diǎn)、使用場(chǎng)景和示例展開(kāi)詳細(xì)的說(shuō)明,感興趣的小伙伴可以跟隨小編一起了解一下
    2022-01-01

最新評(píng)論