React自推出以來,改變了前端開發(fā)人員構(gòu)建web應(yīng)用程序的方式。使用虛擬DOM,React使UI更新更加高效,使web應(yīng)用程序更加快速。但是,為什么中等規(guī)模的React
web應(yīng)用程序仍然表現(xiàn)不佳?React是前端常用的一個(gè)框架,想要學(xué)會(huì)這個(gè)框架的使用技能,建議報(bào)名參加Web前端培訓(xùn),可以在短時(shí)間內(nèi)獲得較大提升。
關(guān)鍵就在于你是如何使用React的。
像React這樣的現(xiàn)代前端庫(kù)并不能神奇地讓你的應(yīng)用程序更快。它要求開發(fā)人員了解React是如何工作的,以及組件在組件生命周期的各個(gè)階段是如何生存的。
使用React,你可以通過測(cè)量和優(yōu)化組件渲染的方式和時(shí)間,獲得它必須提供的許多性能改進(jìn)。而且,React只提供了簡(jiǎn)化此操作所需的工具和功能。
React是如何工作的?
React開發(fā)的核心是簡(jiǎn)單明了的JSX語法,以及React構(gòu)建和比較虛擬DOM的能力。自發(fā)布以來,React影響了許多其他前端庫(kù),諸如Vue.js也依賴于虛擬DOM的思想。
以下是React的工作原理:
每個(gè)React應(yīng)用程序都以根組件開始,并由樹結(jié)構(gòu)中的許多組件組成。React中的組件是“函數(shù)”,它們根據(jù)用戶界面接收的數(shù)據(jù)(道具和狀態(tài))呈現(xiàn)用戶界面。在Web前端培訓(xùn)中,也有關(guān)于React的學(xué)習(xí)和使用,理論知識(shí)結(jié)合實(shí)戰(zhàn)操作,學(xué)以致用,真正掌握前端技術(shù)。
我們可以用F來表示。
UI = F(data)
用戶與UI交互并導(dǎo)致數(shù)據(jù)更改。無論交互涉及單擊按鈕、點(diǎn)擊圖像、拖動(dòng)列表項(xiàng)、AJAX請(qǐng)求調(diào)用API等,所有這些交互都只會(huì)更改數(shù)據(jù)。它們不會(huì)直接導(dǎo)致用戶界面的改變。
在這里,數(shù)據(jù)是定義web應(yīng)用程序狀態(tài)的一切,而不僅僅是存儲(chǔ)在數(shù)據(jù)庫(kù)中的內(nèi)容。甚至前端狀態(tài)的位(例如,當(dāng)前選擇了哪個(gè)選項(xiàng)卡或當(dāng)前是否選中了復(fù)選框)也是該數(shù)據(jù)的一部分。
每當(dāng)此數(shù)據(jù)發(fā)生更改時(shí),React都會(huì)使用組件函數(shù)重新呈現(xiàn)UI,但實(shí)際上僅限于:
UI1=F(data1)
UI2=F(data2)
React通過在其虛擬DOM的兩個(gè)版本上應(yīng)用比較算法來計(jì)算當(dāng)前UI和新UI之間的差異。
Changes = Diff(UI1, UI2)
React然后繼續(xù)僅將UI更改應(yīng)用于瀏覽器上的真實(shí)UI。通過Web前端培訓(xùn)的學(xué)習(xí),你不僅能夠掌握React的技術(shù)應(yīng)用,
也會(huì)對(duì)其底層原理有所了解,并通過實(shí)戰(zhàn)項(xiàng)目,具備獨(dú)立負(fù)責(zé) Vue 前端項(xiàng)目的能力。
當(dāng)與組件關(guān)聯(lián)的數(shù)據(jù)發(fā)生更改時(shí),React確定是否需要實(shí)際的DOM更新。這允許React避免在瀏覽器中進(jìn)行可能非常昂貴的DOM操作,例如創(chuàng)建DOM節(jié)點(diǎn)和訪問現(xiàn)有的DOM節(jié)點(diǎn)。
組件的重復(fù)擴(kuò)散和渲染可能是任何React應(yīng)用程序中React性能問題的主要來源之一。構(gòu)建一個(gè)React應(yīng)用程序,其中擴(kuò)散算法無法有效協(xié)調(diào),導(dǎo)致整個(gè)應(yīng)用程序重復(fù)渲染,可能會(huì)導(dǎo)致令人沮喪的緩慢體驗(yàn)。
要充分利用React,你需要利用它的工具和技術(shù)。React
web應(yīng)用程序的性能在于其組件的簡(jiǎn)單性,在優(yōu)化應(yīng)用程序之前,你需要了解React組件的工作原理以及它們?cè)跒g覽器中的呈現(xiàn)方式。React生命周期方法提供了防止組件不必要地重新渲染的方法。消除這些瓶頸,你將獲得用戶應(yīng)得的應(yīng)用程序性能。參加web前端培訓(xùn),有好的教學(xué)環(huán)境、系統(tǒng)規(guī)范的課程、主流軟件,不光可以擴(kuò)展你的技術(shù),同時(shí)緊貼就業(yè)市場(chǎng)需求設(shè)計(jì)。讓你學(xué)到的技能貼合就業(yè)市場(chǎng),不怕面對(duì)就業(yè)競(jìng)爭(zhēng)對(duì)手。