docs: use dynamic import syntax in examples using lazy loading (#30563)

PR Close #30563
This commit is contained in:
Brandon 2019-05-17 14:31:48 -05:00 committed by Jason Aden
parent 9e946c9715
commit e1af6e3c70
8 changed files with 15 additions and 15 deletions

View File

@ -8,11 +8,11 @@ import { Routes, RouterModule } from '@angular/router';
const routes: Routes = [ const routes: Routes = [
{ {
path: 'customers', path: 'customers',
loadChildren: './customers/customers.module#CustomersModule' loadChildren: () => import('./customers/customers.module').then(mod => mod.CustomersModule)
}, },
{ {
path: 'orders', path: 'orders',
loadChildren: './orders/orders.module#OrdersModule' loadChildren: () => import('./orders/orders.module').then(mod => mod.OrdersModule)
}, },
{ {
path: '', path: '',

View File

@ -3,8 +3,8 @@ import { Routes, RouterModule } from '@angular/router';
export const routes: Routes = [ export const routes: Routes = [
{ path: '', redirectTo: 'contact', pathMatch: 'full'}, { path: '', redirectTo: 'contact', pathMatch: 'full'},
{ path: 'items', loadChildren: './items/items.module#ItemsModule' }, { path: 'items', loadChildren: () => import('./items/items.module').then(mod => mod.ItemsModule) },
{ path: 'customers', loadChildren: './customers/customers.module#CustomersModule' } { path: 'customers', loadChildren: () => import('./customers/customers.module').then(mod => mod.CustomersModule) }
]; ];
@NgModule({ @NgModule({

View File

@ -20,7 +20,7 @@ const appRoutes: Routes = [
// #docregion admin, admin-1 // #docregion admin, admin-1
{ {
path: 'admin', path: 'admin',
loadChildren: './admin/admin.module#AdminModule', loadChildren: () => import('./admin/admin.module').then(mod => mod.AdminModule),
// #enddocregion admin-1 // #enddocregion admin-1
canLoad: [AuthGuard] canLoad: [AuthGuard]
// #docregion admin-1 // #docregion admin-1

View File

@ -21,12 +21,12 @@ const appRoutes: Routes = [
}, },
{ {
path: 'admin', path: 'admin',
loadChildren: './admin/admin.module#AdminModule', loadChildren: () => import('./admin/admin.module').then(mod => mod.AdminModule),
canLoad: [AuthGuard] canLoad: [AuthGuard]
}, },
{ {
path: 'crisis-center', path: 'crisis-center',
loadChildren: './crisis-center/crisis-center.module#CrisisCenterModule' loadChildren: () => import('./crisis-center/crisis-center.module').then(mod => mod.CrisisCenterModule)
}, },
{ path: '', redirectTo: '/heroes', pathMatch: 'full' }, { path: '', redirectTo: '/heroes', pathMatch: 'full' },
{ path: '**', component: PageNotFoundComponent } { path: '**', component: PageNotFoundComponent }

View File

@ -17,13 +17,13 @@ const appRoutes: Routes = [
}, },
{ {
path: 'admin', path: 'admin',
loadChildren: './admin/admin.module#AdminModule', loadChildren: () => import('./admin/admin.module').then(mod => mod.AdminModule),
canLoad: [AuthGuard] canLoad: [AuthGuard]
}, },
// #docregion preload-v2 // #docregion preload-v2
{ {
path: 'crisis-center', path: 'crisis-center',
loadChildren: './crisis-center/crisis-center.module#CrisisCenterModule', loadChildren: () => import('./crisis-center/crisis-center.module').then(mod => mod.CrisisCenterModule),
data: { preload: true } data: { preload: true }
}, },
// #enddocregion preload-v2 // #enddocregion preload-v2

View File

@ -8,7 +8,7 @@ import { AboutComponent } from './about/about.component';
RouterModule.forRoot([ RouterModule.forRoot([
{ path: '', redirectTo: 'dashboard', pathMatch: 'full'}, { path: '', redirectTo: 'dashboard', pathMatch: 'full'},
{ path: 'about', component: AboutComponent }, { path: 'about', component: AboutComponent },
{ path: 'heroes', loadChildren: './hero/hero.module#HeroModule'} { path: 'heroes', loadChildren: () => import('./hero/hero.module').then(mod => mod.HeroModule)}
]) ])
], ],
exports: [ RouterModule ] // re-export the module declarations exports: [ RouterModule ] // re-export the module declarations

View File

@ -143,7 +143,7 @@ In `AppRoutingModule`, update the `routes` array with the following:
</code-example> </code-example>
The import statements stay the same. The first two paths are the routes to the `CustomersModule` and the `OrdersModule` respectively. Notice that the lazy loading syntax uses `loadChildren` followed by a string that is the relative path to the module, a hash mark or `#`, and the modules class name. The import statements stay the same. The first two paths are the routes to the `CustomersModule` and the `OrdersModule` respectively. Notice that the lazy loading syntax uses `loadChildren` followed by a function that uses the browser's built-in `import('...')` syntax for dynamic imports. The import path is the relative path to the module.
### Inside the feature module ### Inside the feature module

View File

@ -3954,10 +3954,10 @@ Users will still visit `/admin` and the `AdminComponent` still serves as the *Ro
Open the `AppRoutingModule` and add a new `admin` route to its `appRoutes` array. Open the `AppRoutingModule` and add a new `admin` route to its `appRoutes` array.
Give it a `loadChildren` property instead of a `children` property, set to the address of the `AdminModule`. Give it a `loadChildren` property instead of a `children` property.
The address is the `AdminModule` file location (relative to the app root), The `loadChildren` property takes a function that returns a promise using the browser's built-in syntax for lazy loading code using dynamic imports `import('...')`.
followed by a `#` separator, followed by the name of the exported module class, `AdminModule`. The path is the location of the `AdminModule` (relative to the app root).
After the code is requested and loaded, the `Promise` resolves an object that contains the `NgModule`, in this case the `AdminModule`.
<code-example path="router/src/app/app-routing.module.5.ts" region="admin-1" header="app-routing.module.ts (load children)"> <code-example path="router/src/app/app-routing.module.5.ts" region="admin-1" header="app-routing.module.ts (load children)">