Skip to content

A Webpack loader that enables string-based module loading with the Angular Router

Notifications You must be signed in to change notification settings

rhessus/angular-router-loader

 
 

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

42 Commits
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

angular-router-loader

CircleCI npm version

A Webpack loader for Angular that enables string-based module loading with the Angular Router

Package was previously named angular2-router-loader

Installation

npm install angular-router-loader --save-dev

Usage

Add the angular-router-loader to your typescript loaders

loaders: [
  {
    test: /\.ts$/,
    loaders: [
      'awesome-typescript-loader',
      'angular-router-loader'
    ]
  }
]

Lazy Loading

In your route configuration, use loadChildren with a relative path to your lazy loaded angular module. The string is delimited with a # where the right side of split is the angular module class name.

import { Routes } from '@angular/router';

export const routes: Routes = [
  { path: 'lazy', loadChildren: './lazy.module#LazyModule' }
];

Synchronous Loading

For synchronous module loading, add the sync=true as a query string value to your loadChildren string. The module will be included in your bundle and not lazy-loaded.

import { Routes } from '@angular/router';

export const routes: Routes = [
  { path: 'lazy', loadChildren: './lazy.module#LazyModule?sync=true' }
];

Additional Documentation

Credits

This loader was inspired by the following projects.

es6-promise-loader by PatrickJS

angular2-template-loader by Sean Larkin

License

MIT (http://www.opensource.org/licenses/mit-license.php)

About

A Webpack loader that enables string-based module loading with the Angular Router

Resources

Stars

Watchers

Forks

Packages

No packages published

Languages

  • JavaScript 100.0%