Angular 2
Chargement paresseux d'un module
Recherche…
Exemple de chargement paresseux
Les modules de chargement paresseux nous aident à réduire le temps de démarrage. Avec le chargement différé, notre application n'a pas besoin de tout charger en une fois, il suffit de charger ce que l'utilisateur s'attend à voir lorsque l'application est chargée pour la première fois. Les modules chargés paresseusement ne seront chargés que lorsque l'utilisateur navigue sur leurs itinéraires.
app / app.module.ts
import { NgModule } from '@angular/core';
import { BrowserModule } from '@angular/platform-browser';
import { AppComponent } from './app.component';
import { EagerComponent } from './eager.component';
import { routing } from './app.routing';
@NgModule({
imports: [
BrowserModule,
routing
],
declarations: [
AppComponent,
EagerComponent
],
bootstrap: [AppComponent]
})
export class AppModule {}
app / app.component.ts
import { Component } from '@angular/core';
@Component({
selector: 'my-app',
template: `<h1>My App</h1> <nav>
<a routerLink="eager">Eager</a>
<a routerLink="lazy">Lazy</a>
</nav>
<router-outlet></router-outlet>
`
})
export class AppComponent {}
app / app.routing.ts
import { ModuleWithProviders } from '@angular/core';
import { Routes, RouterModule } from '@angular/router';
import { EagerComponent } from './eager.component';
const routes: Routes = [
{ path: '', redirectTo: 'eager', pathMatch: 'full' },
{ path: 'eager', component: EagerComponent },
{ path: 'lazy', loadChildren: './lazy.module' }
];
export const routing: ModuleWithProviders = RouterModule.forRoot(routes);
app / eager.component.ts
import { Component } from '@angular/core';
@Component({
template: '`<p>Eager Component</p>`'
})
export class EagerComponent {}
Il n'y a rien de spécial à propos de LazyModule, à part qu'il possède son propre routage et un composant appelé LazyComponent (mais il n'est pas nécessaire de nommer votre module ou un simliar de manière similaire).
app / lazy.module.ts
import { NgModule } from '@angular/core';
import { LazyComponent } from './lazy.component';
import { routing } from './lazy.routing';
@NgModule({
imports: [routing],
declarations: [LazyComponent]
})
export class LazyModule {}
app / lazy.routing.ts
import { ModuleWithProviders } from '@angular/core';
import { Routes, RouterModule } from '@angular/router';
import { LazyComponent } from './lazy.component';
const routes: Routes = [
{ path: '', component: LazyComponent }
];
export const routing: ModuleWithProviders = RouterModule.forChild(routes);
app / lazy.component.ts
import { Component } from '@angular/core';
@Component({
template: `<p>Lazy Component</p>`
})
export class LazyComponent {}