React自推出以來,改變了前端開發人員構建web應用程序的方式。使用虛擬DOM,React使UI更新更加高效,使web應用程序更加快速。但是,為什么中等規模的React web應用程序仍然表現不佳?React是前端常用的一個框架,關鍵就在于你是如何使用React的。
像React這樣的現代前端庫并不能神奇地讓你的應用程序更快。它要求開發人員了解React是如何工作的,以及組件在組件生命周期的各個階段是如何生存的。使用React,你可以通過測量和優化組件渲染的方式和時間,獲得它必須提供的許多性能改進。而且,React只提供了簡化此操作所需的工具和功能。
React是如何工作的?
React開發的核心是簡單明了的JSX語法,以及React構建和比較虛擬DOM的能力。自發布以來,React影響了許多其他前端庫,諸如Vue.js也依賴于虛擬DOM的思想。以下是React的工作原理:
每個React應用程序都以根組件開始,并由樹結構中的許多組件組成。React中的組件是“函數”,它們根據用戶界面接收的數據(道具和狀態)呈現用戶界面。我們可以用F來表示。UI = F(data)
用戶與UI交互并導致數據更改。無論交互涉及單擊按鈕、點擊圖像、拖動列表項、AJAX請求調用API等,所有這些交互都只會更改數據。它們不會直接導致用戶界面的改變。在這里,數據是定義web應用程序狀態的一切,而不僅僅是存儲在數據庫中的內容。甚至前端狀態的位(例如,當前選擇了哪個選項卡或當前是否選中了復選框)也是該數據的一部分。
每當此數據發生更改時,React都會使用組件函數重新呈現UI,但實際上僅限于:UI1=F(data1),UI2=F(data2)。React通過在其虛擬DOM的兩個版本上應用比較算法來計算當前UI和新UI之間的差異。Changes = Diff(UI1, UI2)
React然后繼續僅將UI更改應用于瀏覽器上的真實UI。當與組件關聯的數據發生更改時,React確定是否需要實際的DOM更新。這允許React避免在瀏覽器中進行可能非常昂貴的DOM操作,例如創建DOM節點和訪問現有的DOM節點。
組件的重復擴散和渲染可能是任何React應用程序中React性能問題的主要來源之一。構建一個React應用程序,其中擴散算法無法有效協調,導致整個應用程序重復渲染,可能會導致令人沮喪的緩慢體驗。
要充分利用React,你需要利用它的工具和技術。React web應用程序的性能在于其組件的簡單性,在優化應用程序之前,你需要了解React組件的工作原理以及它們在瀏覽器中的呈現方式。React生命周期方法提供了防止組件不必要地重新渲染的方法。消除這些瓶頸,你將獲得用戶應得的應用程序性能。參加web前端培訓,有好的教學環境、系統規范的課程、主流軟件,不光可以擴展你的技術,同時緊貼就業市場需求設計。讓你學到的技能貼合就業市場,不怕面對就業競爭對手。
本文由培訓無憂網千鋒教育課程顧問老師整理發布,更多web前端課程信息可關注培訓無憂網web前端培訓頻道或添加老師微信:15033336050
注:尊重原創文章,轉載請注明出處和鏈接 http://m.dedgn.cn/news-id-7771.html 違者必究!部分文章來源于網絡由培訓無憂網編輯部人員整理發布,內容真實性請自行核實或聯系我們,了解更多相關資訊請關注web前端頻道查看更多,了解相關專業課程信息您可在線咨詢也可免費申請試課。關注官方微信了解更多:150 3333 6050