React自推出以來(lái),改變了前端開(kāi)發(fā)人員構(gòu)建web應(yīng)用程序的方式。使用虛擬DOM,React使UI更新更加高效,使web應(yīng)用程序更加快速。但是,為什么中等規(guī)模的React web應(yīng)用程序仍然表現(xiàn)不佳?React是前端常用的一個(gè)框架,關(guān)鍵就在于你是如何使用React的。
像React這樣的現(xiàn)代前端庫(kù)并不能神奇地讓你的應(yīng)用程序更快。它要求開(kāi)發(fā)人員了解React是如何工作的,以及組件在組件生命周期的各個(gè)階段是如何生存的。使用React,你可以通過(guò)測(cè)量和優(yōu)化組件渲染的方式和時(shí)間,獲得它必須提供的許多性能改進(jìn)。而且,React只提供了簡(jiǎn)化此操作所需的工具和功能。
React是如何工作的?
React開(kāi)發(fā)的核心是簡(jiǎn)單明了的JSX語(yǔ)法,以及React構(gòu)建和比較虛擬DOM的能力。自發(fā)布以來(lái),React影響了許多其他前端庫(kù),諸如Vue.js也依賴(lài)于虛擬DOM的思想。以下是React的工作原理:
每個(gè)React應(yīng)用程序都以根組件開(kāi)始,并由樹(shù)結(jié)構(gòu)中的許多組件組成。React中的組件是“函數(shù)”,它們根據(jù)用戶(hù)界面接收的數(shù)據(jù)(道具和狀態(tài))呈現(xiàn)用戶(hù)界面。我們可以用F來(lái)表示。UI = F(data)
用戶(hù)與UI交互并導(dǎo)致數(shù)據(jù)更改。無(wú)論交互涉及單擊按鈕、點(diǎn)擊圖像、拖動(dòng)列表項(xiàng)、AJAX請(qǐng)求調(diào)用API等,所有這些交互都只會(huì)更改數(shù)據(jù)。它們不會(huì)直接導(dǎo)致用戶(hù)界面的改變。在這里,數(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通過(guò)在其虛擬DOM的兩個(gè)版本上應(yīng)用比較算法來(lái)計(jì)算當(dāng)前UI和新UI之間的差異。Changes = Diff(UI1, UI2)
React然后繼續(xù)僅將UI更改應(yīng)用于瀏覽器上的真實(shí)UI。當(dāng)與組件關(guān)聯(lián)的數(shù)據(jù)發(fā)生更改時(shí),React確定是否需要實(shí)際的DOM更新。這允許React避免在瀏覽器中進(jìn)行可能非常昂貴的DOM操作,例如創(chuàng)建DOM節(jié)點(diǎn)和訪問(wèn)現(xiàn)有的DOM節(jié)點(diǎn)。
組件的重復(fù)擴(kuò)散和渲染可能是任何React應(yīng)用程序中React性能問(wèn)題的主要來(lái)源之一。構(gòu)建一個(gè)React應(yīng)用程序,其中擴(kuò)散算法無(wú)法有效協(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生命周期方法提供了防止組件不必要地重新渲染的方法。消除這些瓶頸,你將獲得用戶(hù)應(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ì)手。
本文由培訓(xùn)無(wú)憂(yōu)網(wǎng)千鋒教育課程顧問(wèn)老師整理發(fā)布,更多web前端課程信息可關(guān)注培訓(xùn)無(wú)憂(yōu)網(wǎng)web前端培訓(xùn)頻道或添加老師微信:15033336050
注:尊重原創(chuàng)文章,轉(zhuǎn)載請(qǐng)注明出處和鏈接 http://m.hebeijilong.cn/news-id-7771.html 違者必究!部分文章來(lái)源于網(wǎng)絡(luò)由培訓(xùn)無(wú)憂(yōu)網(wǎng)編輯部人員整理發(fā)布,內(nèi)容真實(shí)性請(qǐng)自行核實(shí)或聯(lián)系我們,了解更多相關(guān)資訊請(qǐng)關(guān)注web前端頻道查看更多,了解相關(guān)專(zhuān)業(yè)課程信息您可在線咨詢(xún)也可免費(fèi)申請(qǐng)?jiān)囌n。關(guān)注官方微信了解更多:150 3333 6050