在使用者瀏覽前預先載入路徑,加快瀏覽速度。
路徑層級的程式碼分割可延遲與路徑相關聯的 JavaScript,協助您縮短應用程式的初始載入時間,因為這些路徑在初始階段並非必要。如此一來,Angular 路由器會等到使用者前往特定路徑後,才會觸發網路要求來下載相關的 JavaScript。
雖然這項技術非常適合用於初始網頁載入作業,但視使用者的網路延遲和頻寬而定,可能會減緩瀏覽速度。解決這個問題的方法之一是路由預先載入。使用預先載入功能時,當使用者位於特定路徑時,您可以下載並快取與下一個可能需要的路徑相關聯的 JavaScript。Angular 路由器提供這項功能。
在本篇文章中,您將瞭解如何在使用路徑層級程式碼分割時,利用 Angular 中的 JavaScript 預先載入功能加快導覽速度。
Angular 中的路由預先載入策略
Angular 路由器提供名為 preloadingStrategy
的設定屬性,用於定義預先載入和處理延遲載入 Angular 模組的邏輯。我們將介紹兩種可能的策略:
PreloadAllModules
,顧名思義,會預先載入所有延遲載入的路徑QuicklinkStrategy
,只會預先載入與目前網頁上連結相關聯的路徑。
本篇文章的其餘部分會提到 Angular 應用程式範例。您可以在 GitHub 找到原始碼。
使用 PreloadAllModules
策略
範例應用程式含有多個延遲載入的路徑。如要使用 PreloadAllModules
策略 (已內建於 Angular) 預先載入所有圖片,請在路由器設定中將其指定為 preloadingStrategy
屬性的值:
import { RouterModule, PreloadAllModules } from '@angular/router';
// …
RouterModule.forRoot([
…
], {
preloadingStrategy: PreloadAllModules
})
// …
接著提供應用程式,並查看 Chrome 開發人員工具中的「網路」面板:
- 按下 `Control + Shift + J` 鍵 (在 Mac 上為 `Command + Option + J` 鍵) 開啟開發人員工具。
- 按一下 [網路] 分頁標籤。
開啟應用程式後,您應該會看到路由器在背景下載 nyan-nyan-module.js
和 about-about-module.js
:
路由器也會註冊模組的路徑宣告,因此當您前往與任何預先載入模組相關聯的網址時,轉換作業會立即完成。
使用快速連結預先載入策略
PreloadAllModules
在許多情況下都相當實用。不過,如果您有數十個模組,積極的預先載入功能可能會大幅增加網路用量。此外,由於路由器需要在所有預先載入的模組中註冊路由,因此可能會在 UI 執行緒中造成大量運算,導致使用者體驗緩慢。
quicklink 程式庫可為大型應用程式提供更完善的策略。這個 API 會使用 IntersectionObserver API,只預先載入與目前顯示在網頁上的連結相關聯的模組。
您可以使用 ngx-quicklink 套件,將快速連結新增至 Angular 應用程式。首先,請從 npm 安裝套件:
npm install --save ngx-quicklink
在專案中提供 QuicklinkStrategy
後,您可以指定路由器的 preloadingStrategy
並匯入 QuicklinkModule
,即可使用 QuicklinkStrategy
:
import {QuicklinkStrategy, QuicklinkModule} from 'ngx-quicklink';
…
@NgModule({
…
imports: [
…
QuicklinkModule,
RouterModule.forRoot([…], {
preloadingStrategy: QuicklinkStrategy
})
],
…
})
export class AppModule {}
現在,當您再次開啟應用程式時,您會發現路由器只會預先載入 nyan-nyan-module.js
,因為頁面中央的按鈕有路由器連結。開啟側邊導覽面板後,您會發現路由器會預先載入「About」路徑:
在多個延遲載入模組中使用 Quicklink 預先載入策略
上述範例適用於基本應用程式,但如果您的應用程式含有多個延遲載入的模組,您必須將 QuicklinkModule
匯入共用模組、匯出該模組,然後將共用模組匯入延遲載入的模組。
首先,請將 ngx-quicklink
中的 QuicklinkModule
匯入至共用模組,然後匯出:
import { QuicklinkModule } from 'ngx-quicklink';
…
@NgModule({
…
imports: [
QuicklinkModule
],
exports: [
QuicklinkModule
],
…
})
export class SharedModule {}
接著,將 SharedModule
匯入所有延遲載入的模組:
import { SharedModule } from '@app/shared/shared.module';
…
@NgModule({
…
imports: [
SharedModule
],
…
});
Quicklinks
現在可在延遲載入的模組中使用。
超越基本預先載入
雖然透過快速連結進行選擇性預先載入可大幅加快導覽速度,但您也可以使用預測預先載入功能 (由 Guess.js 實作),讓預先載入策略更有效率。透過分析 Google Analytics 或其他分析供應商的報表,Guess.js 就能預測使用者的瀏覽歷程,並只預先載入下次可能需要的 JavaScript 區塊。
如要瞭解如何搭配使用 Guess.js 和 Angular,請參閱 Guess.js 網站的這個頁面。
結論
如要加快使用路徑層級程式碼分割時的導覽速度,請按照下列步驟操作:
- 根據應用程式大小選擇合適的預先載入策略:
- 模組數量不多的應用程式可以使用 Angular 內建的
PreloadAllModules
策略。 - 含有許多模組的應用程式應使用自訂預先載入策略,例如 Angular 的快速連結或預測預先載入,如同在 Guess.js 中實作。
- 模組數量不多的應用程式可以使用 Angular 內建的
- 設定 Angular 路由器的
preloadStrategy
屬性,藉此設定預先載入策略。