在本文中,我們將快速瀏覽一下可用于盡快創建 Web 應用程序的技巧。如今,擁有一個快速&可持續的Web應用程序對于科技公司來說是一件必不可少的事情,并且擁有這個龐大的Web開發人員社區,實現這個目標比平常容易。
但首先,我想想象一下一個新的JavaScript Web應用程序實際上如何在客戶端工作。
瀏覽器如何理解 JS Web 應用程序?
讓我們通過 Web 應用階段的渲染圖來執行此操作。
對于使用客戶端渲染 (CSR) 方法的所有 JS 應用,此圖片幾乎相同。
構建我們的JS文件下載和渲染的塊,然后我們有我們的網站。看起來很容易,不是嗎?!在這些步驟的引擎蓋下是一個由新方法組成的大黑洞,它幫助我們使這個過程更快,更有效率,所以讓我們來談談它們。
捆綁包和塊
你用 React、Vue.js 或 Angular 格式編寫的代碼在編寫時和渲染時不會相同,代碼由模塊捆綁器轉換為許多片段、塊或捆綁包,并帶有向后兼容和純 JS 代碼,讓瀏覽器理解代碼并向用戶呈現一個外觀正常的網站。讓我用一個由網絡包捆綁的小型React應用程序向您展示它。
這是我們編寫的代碼
這是由 web 包生成的上一個代碼包的一部分
看!Webpack會將所有的Lodash代碼導入到一個文件中,其中包含我們已經編寫的JS代碼!此文件包將被發送到瀏覽器,并在下載完成后開始呈現。因此,想象一個大塊文件 - 下載它的速度有多慢!
優化
這里的大部分速度技巧都是關于通過執行諸如延遲加載,編寫自定義庫而不是全部安裝它們,壓縮塊文件和Core Web Vite之類的事情來減小塊文件大小(我也寫了一篇關于此的文章,您可以在此處閱讀)。所以讓我們來做吧。
延遲加載和代碼拆分
這里的主要概念是防止加載不必要的代碼或在用戶需要的某些邏輯點加載它們,這樣我們就不會在第一次或每次刷新時加載整個塊,而只導入和下載我們當時需要的代碼!
模塊捆綁器
這個概念對于選擇Webpack的開發人員來說非常簡單,但現在比以前要棘手得多,因為最近出現了一些很酷的新模塊捆綁器,使這個過程比以前越來越高性能,我現在選擇這部分是Vite!
但是為什么維特比網絡包更好呢?
Vite 更喜歡提供源代碼而不是本機 ESM。通過允許瀏覽器執行捆綁器的部分職責,Vite可以根據瀏覽器的要求根據需要更改源代碼。僅當在當前屏幕上使用條件動態導入背后的代碼時,才會處理該代碼。
壓縮
這個東西是由大多數當前的模塊捆綁器處理的,但這里的一個技巧是使用Brotli作為傳統GZIP算法以外的壓縮算法,Brotli將捆綁軟件大小減少了20%-30%!是的,這很酷。