亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 編程 > JavaScript > 正文

詳解使用路由延遲加載 Angular 模塊

2019-11-19 15:11:30
字體:
來源:轉載
供稿:網友

Angular 非常模塊化,模塊化的一個非常有用的特性就是模塊作為延遲加載點。延遲加載意味著可以在后臺加載一個模塊和其包含的所有組件等資源。這樣 Angular 就不需要在第一個界面從服務器下載所有的文件,直到您請求它,才下載相應的模塊。這對提供性能和減少首屏的初始下載文件尺寸有巨大的幫助。而且它可以很容易設置。

這里將使用一個簡單示例來演示這個特性是如何工作的。將應用拆分為多個不同的模塊,可以在需要的時候再進行延遲加載。

延遲加載的路由需要在根模塊之外定義,所以,你需要將需要延遲加載的功能包含在功能模塊中。

我們使用 Angular CLI 來創建一個演示項目:Demo.

ng new demo

然后,進入到 demo 文件夾中。安裝必要的 package。

npm i

在安裝之后,我們創建一個新的模塊 shop。在 angular CLI 中,ng 是命令提示指令,g 表示 generate,用來創建某類新 item。

創建新的名為 shop 的模塊就是:

ng g module shop

這會導致在 Angular 項目的 src/app 文件下創建一個新的文件夾,并添加一個名為 shop.module.ts 的模塊定義文件。

然后,我們在默認的 app 模塊和新創建的 shop 模塊中分別創建組件。

ng g c home/homeng g c shop/cartng g c shop/checkout ng g c shop/confirm

CLI 會將 home 分配到 app 模塊中,將 cart、checkout、confirm 分配到 shop 模塊中,比如,

此時的 shop.module.ts 內容如下:

import { NgModule } from '@angular/core';import { CommonModule } from '@angular/common';import { CheckoutComponent } from './checkout/checkout.component';import { CartComponent } from './cart/cart.component';import { ConfirmComponent } from './confirm/confirm.component';@NgModule({ imports: [  CommonModule ], declarations: [CheckoutComponent, CartComponent, ConfirmComponent]})export class ShopModule { }

修改根組件

Angular CLI 默認生成的 app.component.ts 組件是應用的主頁面,其中包含了一些關于 Angular 的介紹信息,我們將它修改成我們需要的內容。將默認生成的 app.component.html 內容修改為如下內容。

<!--The content below is only a placeholder and can be replaced.--><h1>Lazy Load Module</h1><a [routerLink]="['/shop']" >Shop Cart</a><router-outlet></router-outlet>

這里提供了一個占位的 router-outlet,各個組件將顯示在這里面。

同時,提供了一個導航鏈接,可以直接導航到 /shop/cart 組件。

創建路由

根路由

首先創建根路由。

我們在 app 文件夾中,添加一個名為 main.routing.ts 的路由配置文件。內容如下:

import { Routes } from '@angular/router';// HomeComponent this components will be eager loadedimport { HomeComponent } from './home/home.component';export const routes: Routes = [  { path: '', component: HomeComponent, pathMatch: 'full' },  { path: 'shop', loadChildren: './shop/shop.module#ShopModule' },  { path: '**', component: HomeComponent }];

其中,home 組件是正常的提前加載。

需要注意的是一下幾點:

1. 我們使用了 loadChildren 來延遲加載一個模塊。而不是使用提前加載所使用的 component。
2. 我們使用了一個字符串而不是符號來避免提前加載。
3. 我們不僅定義了模塊的路徑,還提供了模塊的類名。

在 app.module.ts 中啟用根路由。主要需要使用 forRoot 來啟用根路由。

import { BrowserModule } from '@angular/platform-browser';import { NgModule } from '@angular/core';import { AppComponent } from './app.component';import { HomeComponent } from './home/home.component';import { routes } from './main.routing';import { RouterModule } from '@angular/router';@NgModule({ declarations: [  AppComponent,  HomeComponent ], imports: [  BrowserModule,  RouterModule.forRoot(routes) ], providers: [], bootstrap: [AppComponent]})export class AppModule { }

模塊路由

定義模塊路由

對于 shop 模塊來說,定義路由就沒有什么特別了,我們這里可以定義一個名為 shop.route.ts 的路由定義文件,內容如下所示:

import { Routes } from '@angular/router'; import { CartComponent } from './cart/cart.component'; import { CheckoutComponent } from './checkout/checkout.component'; import { ConfirmComponent } from './confirm/confirm.component'; export const routes: Routes = [        { path: '', component: CartComponent },        { path: 'checkout', component: CheckoutComponent },       { path: 'confirm', component: ConfirmComponent } ];

還需要修改一下模塊定義文件 shop.module.ts 文件,以使用這個路由定義。注意我們需要使用 forChild 來啟用子路由。

import { NgModule } from '@angular/core';import { CommonModule } from '@angular/common';import { CheckoutComponent } from './checkout/checkout.component';import { CartComponent } from './cart/cart.component';import { ConfirmComponent } from './confirm/confirm.component';import { routes } from './shop.routing'; import { RouterModule } from '@angular/router';@NgModule({ imports: [  CommonModule,  RouterModule.forChild(routes) ], declarations: [CheckoutComponent, CartComponent, ConfirmComponent]})export class ShopModule { }

已經一切就緒了。

測試延遲加載

現在啟動應用。

ng serve

默認會在 4200 端口啟動應用,請打開瀏覽器,訪問:http://localhost:4200/

訪問首頁的網絡訪問如下,其中并不包含功能模塊的內容。

我們先將網絡請求的歷史記錄清除掉。

然后點擊鏈接,訪問 /shop/cart 的時候,網絡請求如下,可以看到一個新的腳本文件被加載,這里包含的就是延遲加載的功能模塊。

僅僅功能模塊被加載了。

以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持武林網。

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
国产欧美日韩中文字幕在线| 欧美精品中文字幕一区| 欧美激情在线视频二区| 亚洲精品美女在线观看播放| 97在线精品视频| 日韩精品中文字| 97视频在线观看免费高清完整版在线观看| 91国偷自产一区二区三区的观看方式| 91国语精品自产拍在线观看性色| 91高清免费在线观看| 欧美日韩亚洲精品内裤| 97精品国产aⅴ7777| 日韩在线视频线视频免费网站| 久久久久亚洲精品成人网小说| 国产69精品久久久久99| 国产香蕉一区二区三区在线视频| 亚洲人成在线免费观看| 国产精品久久一区| 成人福利视频在线观看| 欧美亚洲视频在线观看| 91免费欧美精品| 欧美日本高清一区| 久久久人成影片一区二区三区观看| 高清欧美性猛交xxxx黑人猛交| 亚洲国产日韩一区| 国产精品久久久久久久久久三级| 欧美高清激情视频| 精品国产区一区二区三区在线观看| 91免费看视频.| 麻豆乱码国产一区二区三区| 日本高清久久天堂| 亚洲天堂开心观看| 国产v综合ⅴ日韩v欧美大片| 亚洲国产精品va在线看黑人动漫| 亚洲欧美激情精品一区二区| 日本午夜人人精品| 国内成人精品一区| 久久久国产影院| 国产视频精品va久久久久久| 热久久视久久精品18亚洲精品| 欧美巨猛xxxx猛交黑人97人| 精品视频—区二区三区免费| 国产精品福利在线| 日韩av在线直播| 亚洲色图av在线| 国产精品三级网站| 国产在线视频欧美| 亚洲欧洲美洲在线综合| 久久精视频免费在线久久完整在线看| 国产福利视频一区| 国产主播喷水一区二区| 久久精品国产欧美亚洲人人爽| 91久久在线播放| 国产精品aaa| 91免费视频国产| 欧美xxxx综合视频| 久久精品国产一区二区电影| 欧美国产在线电影| 久久精品国产91精品亚洲| 国产精品综合网站| 日韩av免费一区| 久久精品久久久久久| 日本一区二区三区四区视频| 国产成人黄色av| 久久久国产91| 91情侣偷在线精品国产| 亚洲欧美日韩一区二区在线| 欧美尤物巨大精品爽| 色播久久人人爽人人爽人人片视av| 亚洲人成免费电影| 欧美成人免费播放| 国产美女久久精品香蕉69| 欧美国产日韩视频| 欧美日韩性视频在线| 日韩欧美国产一区二区| 欧美精品免费在线| 亚洲网站在线观看| 亚洲国内精品视频| 亚洲成人激情在线观看| 国产精品免费小视频| 日韩精品在线看| 国产精品久久97| 国产成人免费av电影| 国产成人一区三区| 久久视频免费观看| 69国产精品成人在线播放| 91午夜理伦私人影院| 日本精品免费一区二区三区| 美女av一区二区三区| 日韩精品免费一线在线观看| 蜜臀久久99精品久久久无需会员| 欧美性猛交xxxx富婆弯腰| 欧日韩不卡在线视频| 91美女高潮出水| 国内精品中文字幕| 91精品视频免费观看| 亚洲欧美成人网| 中文字幕亚洲综合久久筱田步美| 欧美成人sm免费视频| 俺去了亚洲欧美日韩| 亚洲一区二区三区香蕉| 国产精品一区二区3区| 亚洲aaa激情| 日韩高清电影好看的电视剧电影| 欧美极品xxxx| 成人精品久久久| 成人精品在线观看| 疯狂做受xxxx高潮欧美日本| 欧美激情一区二区三级高清视频| 欧洲永久精品大片ww免费漫画| 国产97在线亚洲| 成人午夜在线视频一区| 国产精品永久免费观看| 欧美乱人伦中文字幕在线| 久久av红桃一区二区小说| 久久久免费av| 国产在线精品成人一区二区三区| 一本久久综合亚洲鲁鲁| 国产成人综合亚洲| 欧美区二区三区| 国语自产精品视频在线看一大j8| 日韩av在线一区| 久久久久久国产三级电影| 亚洲国产欧美一区二区三区久久| 日韩福利伦理影院免费| 成人久久18免费网站图片| 欧美午夜影院在线视频| 精品欧美一区二区三区| 亚洲人永久免费| 亚洲欧洲国产伦综合| 欧美电影电视剧在线观看| 伊人激情综合网| 欧美精品久久久久| 色播久久人人爽人人爽人人片视av| 亚洲国产精品大全| 91精品国产亚洲| 亚洲欧美日韩天堂| 国产亚洲欧洲高清| 国产91免费观看| 亚洲va电影大全| 成人深夜直播免费观看| 97成人精品视频在线观看| xxx成人少妇69| 日本欧美爱爱爱| 麻豆一区二区在线观看| 日韩小视频在线观看| 欧美日韩一区二区三区| 久久久久久91香蕉国产| 精品国偷自产在线| 色婷婷综合久久久久| 国产精品久久国产精品99gif| 亚洲福利在线观看| 精品无码久久久久久国产| 成人在线激情视频| 国产精品1234| 在线电影中文日韩| 国产精欧美一区二区三区| 性色av香蕉一区二区| 日韩激情av在线免费观看| 色悠久久久久综合先锋影音下载| 欧美国产日韩一区二区| 欧美日韩一区免费| 青草热久免费精品视频| 91精品免费久久久久久久久|