欧美一级特黄大片做受成人-亚洲成人一区二区电影-激情熟女一区二区三区-日韩专区欧美专区国产专区

vue和react的區(qū)別是什么-創(chuàng)新互聯(lián)

本文小編為大家詳細介紹“vue和react的區(qū)別是什么”,內(nèi)容詳細,步驟清晰,細節(jié)處理妥當,希望這篇“vue和react的區(qū)別是什么”文章能幫助大家解決疑惑,下面跟著小編的思路慢慢深入,一起來學(xué)習(xí)新知識吧。

主要從事網(wǎng)頁設(shè)計、PC網(wǎng)站建設(shè)(電腦版網(wǎng)站建設(shè))、wap網(wǎng)站建設(shè)(手機版網(wǎng)站建設(shè))、成都響應(yīng)式網(wǎng)站建設(shè)、程序開發(fā)、微網(wǎng)站、小程序設(shè)計等,憑借多年來在互聯(lián)網(wǎng)的打拼,我們在互聯(lián)網(wǎng)網(wǎng)站建設(shè)行業(yè)積累了豐富的成都網(wǎng)站制作、網(wǎng)站設(shè)計、外貿(mào)網(wǎng)站建設(shè)、網(wǎng)絡(luò)營銷經(jīng)驗,集策劃、開發(fā)、設(shè)計、營銷、管理等多方位專業(yè)化運作于一體,具備承接不同規(guī)模與類型的建設(shè)項目的能力。

具體分析如下:

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

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

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

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

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

React一直不支持雙向綁定,提倡的是單向數(shù)據(jù)流,稱之為onChange/setState()模式。不過由于我們一般都會用Vuex以及Redux等單向數(shù)據(jù)流的狀態(tài)管理框架,因此很多時候我們感受不到這一點的區(qū)別了。

3.HoC和mixins

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

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

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

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

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

5.模板渲染方式的不同

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

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

舉個例子,說明React的好處:react中render函數(shù)是支持閉包特性的,所以我們import的組件在render中可以直接調(diào)用。但是在Vue中,由于模板中使用的數(shù)據(jù)都必須掛在 this 上進行一次中轉(zhuǎn),所以我們import 一個組件完了之后,還需要在 components 中再聲明下,這樣顯然是很奇怪但又不得不這樣的做法。

6.渲染過程不同

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

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

如果應(yīng)用中交互復(fù)雜,需要處理大量的UI變化,那么使用Virtual DOM是一個好主意。如果更新元素并不頻繁,那么Virtual DOM并不一定適用,性能很可能還不如直接操控DOM。

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

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

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

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

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

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

讀到這里,這篇“vue和react的區(qū)別是什么”文章已經(jīng)介紹完畢,想要掌握這篇文章的知識點還需要大家自己動手實踐使用過才能領(lǐng)會,如果想了解更多相關(guān)內(nèi)容的文章,歡迎關(guān)注創(chuàng)新互聯(lián)-成都網(wǎng)站建設(shè)公司行業(yè)資訊頻道。

分享標題:vue和react的區(qū)別是什么-創(chuàng)新互聯(lián)
標題網(wǎng)址:http://aaarwkj.com/article2/gosoc.html

成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供網(wǎng)站制作網(wǎng)站排名、建站公司、網(wǎng)站改版微信小程序、網(wǎng)站收錄

廣告

聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請盡快告知,我們將會在第一時間刪除。文章觀點不代表本網(wǎng)站立場,如需處理請聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時需注明來源: 創(chuàng)新互聯(lián)

搜索引擎優(yōu)化
尤物视频官网在线观看| 一区二区三区三级视频| 黄色成人av在线网站| 情五月激情亚洲丁香佳色| 无遮挡国产精品一级二级三级视频 | 国产伦国产一区二区三区在线观看| 动漫美女视频在线看黄| 懂色粉嫩蜜臀久久一区二区| 精品国产91乱码一区二区三区| 成人三级中文字幕电影| 亚洲精品老司机福利在线| 国产人妖cd蜜雅丝袜美女| 国产av无毛一区二区三区| 91狠狠综合久久精品| 日韩毛片中文字幕在线观看| 人成午夜视频在线播放| 美国真人性做爰视频免费| 久久精品亚洲精品国产| 欧美高清精品在线视频| 亚洲精品一区二区av| 人妻久久久久久精品99| 蜜桃视频在线观看91| 有码不卡中文字幕在线视频| 日本免费91午夜视频| 国产网红女主播视频一区二区| 免费在线观看一区二区三区视频| 精品欧美自拍偷拍三区| av在线观看亚洲天堂| 日本一区二区三区免费黄视频| 亚洲综合中文字幕经典av在线| 97色伦97色伦国产在线| 精品国产成人一区二区| 成人一区二区三区播放| 国产精品三级玖玖玖电影| 羞羞的视频免费观看在线| 亚洲97成人在线视频| 国产精品超碰在线观看| 亚洲国产日韩一区二区在线| 日本在线免费观看91| 欧美成人精品午夜一区二区| 亚洲国产日韩欧美视频|