一文帶你了解Vue?和?React的區(qū)別
說說 Vue 和 React 的區(qū)別
青銅級
只要真正了解一些,或者用過兩個框架開發(fā),就一定能說上來的一些語法層面:
Vue API多,React API少Vue雙向綁定,修改數(shù)據(jù)自動更新視圖,而React單向數(shù)據(jù)流,需要手動setStateVue template結(jié)構(gòu)表現(xiàn)分離,React用jsx結(jié)構(gòu)表現(xiàn)融合,html/css都可以寫到j(luò)s里- 都可以通過
props進行父子組件數(shù)據(jù)傳遞,只是Vue props要聲明,React不用聲明可能直接使用 Vue可以用插槽,React是萬物皆可propsVue2利用基本都是Mixin,React可以用高階函數(shù)、自定義hook實現(xiàn)Vue的frgments、hook到Vue3才有,Vue還有豐富的指令,過濾器
都支持服務(wù)端渲染,都有虛擬 DOM,數(shù)據(jù)驅(qū)動,組件化開發(fā),響應(yīng)式,組件通信,生命周期,Diff,都有狀態(tài)管理 Vuex/Pinia、Redux/Mobx,等等等等....
白銀級
- 可以加一些偏感受方面的,比如:
React 官方只關(guān)注底層,上層應(yīng)用解決方案都交給社區(qū),所以 React 生態(tài)體系豐富,社區(qū)強,而且每次更新改動小等 等,而 Vue 是由官方主導(dǎo)開發(fā)和維護,生態(tài)沒那么豐富,雖然上手比 React 簡單一些,但每次更新堪稱破土重來,改的倒是瀟灑得很,這就注定我們學(xué)習(xí)成本大大增加,并不能做到學(xué)習(xí)一次就可以一直使用這個框架,1.0 改版 2.0 需要重新學(xué)習(xí)一遍,2.0 改版 3.0 又要學(xué)習(xí)一遍,甚至 3.0 到 3.2 都要重學(xué)一部分,有些程序員到了 35 退休不是不想干,也是學(xué)不動了吧。像是需要記的 API,React 就那么幾個,剩下的自己去寫就行了,Vue 雖然在代碼維護上有一定優(yōu)勢,可是它的 API 就多得多了,而且還分版本,比如 Vue2 有過濾器,Vue3 卻沒了,不僅要多記很多 API 和自定義指令,還需要對自己所學(xué)的 API 根據(jù)版本進行選擇使用,感覺不怎么嚴謹
- 也可以將青銅級上面的某些點展開說一下細節(jié),比如:
組件化:
Vue2組件說白了就是一個掛滿一堆東西的Vue核心類,通過new Vue()拿到實例。就是說Vue組件的script導(dǎo)出的是一個掛滿各種options的純對象而已,所以options API的this指向Vue實例,這對我們開發(fā)者來說是不透明的,需要文檔才能知道上面一堆this.$xxx是干嘛用的,而且Vue的插件也都是基于Vue原型類基礎(chǔ)上的,Vue.install掛到Vue實例上去嘛,以保證和第三方庫的Vue調(diào)的是同一個Vue對象- 而
React則比較簡單,直接定義render函數(shù)生成vnode,里面通過四個組件類包裝vnode而已,不同類型的vnode用相對應(yīng)的組件類處理,就像責任劃分一樣,各自只負責自己的。而且React類組件都是繼承于React.Component類,它的this指向我們自定義的類,可以說對我們開發(fā)者來說是透明的
hook:
React hook是根據(jù)調(diào)用順序來確定下一次重新渲染時的state是來源于哪個,所以有一些限制,比如不能在循環(huán)/條件判斷/嵌套函數(shù)里使用,而且必須在函數(shù)最頂層調(diào)用hook等Vue3 hook是基于響應(yīng)式實現(xiàn)的,它是聲明在setup里,一次組件實例化只調(diào)用一次setup,而React每次重新渲染都要重新調(diào)用,性能上自然不言而喻,而且可以在循環(huán)/條件判斷/嵌套函數(shù)里使用,并且正因為是基于響應(yīng)式實現(xiàn)的,還自動實現(xiàn)了依賴收集,而React需要手動傳入依賴等
等等...
黃金級
起碼得深入源碼吧,比如:
響應(yīng)式:
Vue2響應(yīng)式的特點就是依賴收集,數(shù)據(jù)可變,自動派發(fā)更新,初始化時通過Object.defineProperty遞歸劫持data所有屬性添加getter/setter,觸發(fā)getter的時候進行依賴收集,修改時觸發(fā)etter自動派發(fā)更新找到引用組件重新渲染Vue3響應(yīng)式使用原生Proxy重構(gòu)了響應(yīng)式,一是proxy不存在響應(yīng)式存在的缺陷,二是性能更好,不僅支持更多的數(shù)據(jù)結(jié)構(gòu),而且不再一開始遞歸劫持對象屬性,而是代理第一層對象本身。運行時才遞歸,用到才代理,用effect副作用來代替Vue2里的watcher,用一個依賴管理中心trackMap來統(tǒng)一管理依賴代替Vue2中的Dep,這樣也不需要維護特別多的依賴關(guān)系,性能上取得很大進步- 相比
Vue的自動化,eact則是基于狀態(tài),單向數(shù)據(jù)流,數(shù)據(jù)不可變,需要手動setState來更新,而且當數(shù)據(jù)改變時會以組件根為目錄,默認全部重新渲染整個組件樹,只能額外用pureComponent/shouldComponentUpdate/useMemo/useCallback等方法來進行控制,更新粒度更大一些
Diff 算法:
Vue2是同層比較新老vnode,新的不存在老的存在就刪除,新的存在老的不存在就創(chuàng)建,子節(jié)點采用雙指針頭對尾兩端對比的方式,全量diff,然后移動節(jié)點時通過splice進行數(shù)組操作Vue3是采用Map數(shù)據(jù)結(jié)構(gòu)以及動靜結(jié)合的方式,在編譯階段提前標記靜態(tài)節(jié)點,Diff過程中直接跳過有靜態(tài)標記的節(jié)點,并且子節(jié)點對比會使用一個source數(shù)組來記錄節(jié)點位置及最長遞增子序列算法優(yōu)化了對比流程,快速Diff,需要處理的邊際條件會更少React是遞歸同層比較,標識差異點保存到Diff隊列保存,得到patch樹,再統(tǒng)一操作批量更新DOM。Diff總共就是移動、刪除、增加三個操作,如果結(jié)構(gòu)發(fā)生改變就直接卸載重新創(chuàng)建,如果沒有則將節(jié)點在新集合中的位置和老集合中的lastIndex進行比較是否需要移動,如果遍歷過程中發(fā)現(xiàn)新集合沒有,但老集合有就刪除
鉆石級
這得要脫離代碼層面,上升到更加宏觀的層面吧,區(qū)別擺在那里是死的,固定的,就主要看人怎么說了,比如
- 以突出核心思想和設(shè)計理念開頭:
我覺得最主要就是核心思想和設(shè)計理念上的區(qū)別,React 一開始定位的就是 UI 開發(fā)的新思路,這種思想說白了就是要改變開發(fā)者,我制定規(guī)則,你們都照我的來,因為背靠大公司(facebook),所以不缺用戶,而 Vue 是盡可能降低前端開發(fā)的門檻來適應(yīng)不同的開發(fā)者,讓開發(fā)者怎么爽怎么來,正是因為這種設(shè)計理念上的差別對后續(xù)設(shè)計也產(chǎn)生了一些不可逆的影響,或者說這兩框架后續(xù)架構(gòu)的變化都是圍繞這個來的。
- 以突出數(shù)據(jù)管理開頭:
我覺得這兩最主要的區(qū)別是在數(shù)據(jù)管理方式上,雖然都是數(shù)據(jù)驅(qū)動,但 Vue 是響應(yīng)式的,React 是手 setState,可以說正是因為這個對后面架構(gòu)的設(shè)計都產(chǎn)生了一些不可逆的影響,或者說這兩框架后續(xù)架構(gòu)的變化都是圍繞這個來的。
主要體現(xiàn)在這些方面:
比如 Vue 是對數(shù)據(jù)進行劫持/代理,它對監(jiān)測數(shù)據(jù)的變化更加精準,動了多少數(shù)據(jù)就觸發(fā)多少更新,更新粒度很小,而 React 推崇函數(shù)式,這是沒辦法感知數(shù)據(jù)變化的,就是說不知道什么時候應(yīng)該刷新,而且即便是手動 setState 觸發(fā)更新,它也也不知道哪些組件需要刷新,而是渲染整個 DOM,說白了就是無腦刷新嘛,這樣就導(dǎo)致性能不好,所以后面只能不斷通過其他辦法來避免不必要的刷新,或者優(yōu)化無腦刷新的性能。當然 Vue 也不是那么完美,它實現(xiàn)精準刷新也是有代價的,就是需要給每個組件配置監(jiān)視器,管理依賴收集和派發(fā)更新,這同樣是有消耗的。且不是說性能誰好吧,我們可以對比下這兩框架版本迭代可以發(fā)現(xiàn),React 迭代是增加了一個個避免刷新的鉤子函數(shù)或者 API 還有采用 Fiber 的架構(gòu)來做時間分片也是來優(yōu)化渲染的性能。而 Vue1/Vue2/Vue3 每個版本雖然改的東西多,但核心都是圍繞響應(yīng)式來優(yōu)化的,所以我覺得這是這兩框架之間最重要的區(qū)別
比如正是這種設(shè)計上的區(qū)別,也直接影響了 hooks 的實現(xiàn)和表現(xiàn),React hook 底層是基于鏈表實現(xiàn)的,每次組件被 render 的時候都會按順序執(zhí)行所有 hooks,而且正因為底層是鏈表,每個 hook 的 next 是指向下一個 hook 的,所以我們寫代碼是不能在不同的 hooks 調(diào)用里使用條件判斷/函數(shù)嵌套之類的,因為這會導(dǎo)致執(zhí)行順序不對,從而出錯。而 Vue hook 只會被注冊調(diào)用一次,因為它是聲明在 setup 里,一次組件實例化只調(diào)用一次 setup,Vue 之所以能避開這些問題,主要還是得益于數(shù)據(jù)響應(yīng)式,不需要鏈表對 hooks 進行記錄,而是直接對數(shù)據(jù)代理觀察,但它也有困擾的地方,就是不得不返回一個包裝對象,通過 .value 獲取。因為在 JS 里基礎(chǔ)類型只有值,沒有引用,或者說只存在棧里,使用完就回收了,無法追蹤后續(xù)變化,自然做不到數(shù)據(jù)的代理和攔截,這算是這個設(shè)計的一個缺點吧
再比如編譯優(yōu)化的問題,Vue 能夠做到數(shù)據(jù)劫持,再到 Vue3 動靜結(jié)合的 Diff 思想也得益于它的模板語法實現(xiàn)了靜態(tài)編譯。就是能做到預(yù)編譯優(yōu)化,可以靜態(tài)分析,在解析模板時能根據(jù)解析到的不同的標簽、文本等分別執(zhí)行對應(yīng)的回調(diào)函數(shù)來構(gòu)造 AST,而 React 雖然 JSX 語法更加靈活,可也正是因為這樣導(dǎo)致可以優(yōu)化的地方不足,重新渲染時就是一堆遞歸調(diào)用 React.createElement,無法從模板層面進行靜態(tài)分析,也就做不到雙向綁定,即使是很厲害的 fiber,也是因為傷害已經(jīng)造成,所以通過時間分片的優(yōu)化來彌補傷害吧,因為已經(jīng)無法在編譯階段進行優(yōu)化了,這也是這個設(shè)計所帶來的問題吧
項目選型怎么考慮?怎么選擇?
從加載速度,運行時性能來說,我覺得這兩個框架綜合各種場景應(yīng)該是沒什么質(zhì)的差別的。硬要說的話,Vue 在更新時性能優(yōu)化方面需要的心智負擔可能會少那么一點,特別是 Vue3,而 React 如果不注意,容易導(dǎo)致一些組件無用的 Diff,但其實實際項目中真正能遇到這種性能瓶頸的也是極少數(shù),所以(這里有兩種說法):
(如果公司主要用 Vue 技術(shù)棧的話):所以總的來說我覺得 Vue 性能上會更有優(yōu)勢一點,特別是 Vue3 更加靈活,有很好的可擴展性,同時有更快的渲染速度和更小的打包體積。從 mixins 到 HOC 到 render props 再到 hooks,React 基本已經(jīng)廢掉了過去很多基于組件的邏輯抽象模式,抹掉了 JSX 對比模板的一個優(yōu)勢,Vue3 中現(xiàn)在也都能做到,所以我會偏向 Vue3。
(如果公司主要用 React 技術(shù)棧的話):所以總的來說我覺得要是一些不大的系統(tǒng)或者 H5 就用 Vue,因為不管是上手還是開發(fā)難度上都很簡單,開發(fā)效率也高嘛,而且它有更小的打包體積,畢竟在移動端網(wǎng)絡(luò)差異大的情況下,資源體積是非常重要的。但像是一些中后臺系統(tǒng),或者一些大點的項目,會越做越大的,多人協(xié)作開發(fā)的,就用 React,因為它的函數(shù)式編程有更加靈活的結(jié)構(gòu)和可擴展性,豐富的生態(tài)圈和工具鏈,解決方案多,后期也更方便迭代與維護,還適用原生 APP,所以我會偏向 React。
你覺得這兩框架哪個厲害
這個,我覺得吧,我們討論這個問題的時候,可能由于咱倆關(guān)于這一塊兒的信息不對等,只是表達自己想法的話,有可能會變成兩個陣營的,而且即使證明了一個比另一個牛比,也不意味著我的項目就牛比了,反正好用就都學(xué),讓自己變得厲害才更靠譜一點
結(jié)語
如果本文對你有一點點幫助,點個贊支持一下吧,你的每一個【贊】都是我創(chuàng)作的最大動力 ^_^
到此這篇關(guān)于一文帶你了解Vue 和 React的區(qū)別的文章就介紹到這了,更多相關(guān)Vue 和 React區(qū)別內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
vue+element多選級聯(lián)選擇器自定義props使用詳解
這篇文章主要給大家介紹了關(guān)于vue+element多選級聯(lián)選擇器自定義props使用的相關(guān)資料,級聯(lián)選擇器展示的結(jié)果都是以數(shù)組的形式展示,也就是v-model綁定的結(jié)果,需要的朋友可以參考下2023-07-07
淺談vue3中effect與computed的親密關(guān)系
這篇文章主要介紹了淺談vue3中effect與computed的親密關(guān)系,文中通過示例代碼介紹的非常詳細,對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2019-10-10
動態(tài)實現(xiàn)element ui的el-table某列數(shù)據(jù)不同樣式的示例
這篇文章主要介紹了動態(tài)實現(xiàn)element ui的el-table某列數(shù)據(jù)不同樣式的示例,文中通過示例代碼介紹的非常詳細,對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2021-01-01
VUE 配置vue-devtools調(diào)試工具及安裝方法
vue-devtools是一款基于chrome瀏覽器的插件,用于vue應(yīng)用的調(diào)試,這款vue調(diào)試神器可以極大地提高我們的調(diào)試效率。幫助我們快速的調(diào)試開發(fā)vue應(yīng)用。這篇文章主要介紹了VUE 配置vue-devtools調(diào)試工具及安裝步驟 ,需要的朋友可以參考下2018-09-09
詳解swiper在vue中的應(yīng)用(以3.0為例)
這篇文章主要介紹了詳解swiper在vue中的應(yīng)用(以3.0為例),小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧2018-09-09
Vue設(shè)置別名聯(lián)想路徑即@/生效的方法
這篇文章主要給大家介紹了Vue設(shè)置別名聯(lián)想路徑即@/生效的方法,文中有詳細的代碼示例和圖文講解,具有一定的參考價值,需要的朋友可以參考下2023-11-11
讓webpack+vue-cil項目不再自動打開瀏覽器的方法
今天小編就為大家分享一篇讓webpack+vue-cil項目不再自動打開瀏覽器的方法,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧2018-09-09
Vue實現(xiàn)一種簡單的無限循環(huán)滾動動畫的示例
這篇文章主要介紹了Vue實現(xiàn)一種簡單的無限循環(huán)滾動動畫的示例,文中通過示例代碼介紹的非常詳細,對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2021-01-01

