Skip to content

Latest commit

 

History

History
142 lines (114 loc) · 2.69 KB

options.md

File metadata and controls

142 lines (114 loc) · 2.69 KB

General Loader Options

Options are provided as a query string with the angular-router-loader

loaders: [
  'angular-router-loader?option=value'
]

debug: (default: false)

Logs the file, loadChildren string found and replacement string used to the console.

loader: (default: 'require')

Sets the loader string returned for code splitting.

original

{
  path: 'lazy',
  loadChildren './lazy.module#LazyModule'
}

replacement

{
  path: 'lazy',
  loadChildren: () => new Promise(function (resolve) {
    (require as any).ensure([], function (require: any) {
      resolve(require('./lazy/lazy.module')['LazyModule']);
    });
  })
}

If you prefer to use System.import, set the loader to system

NOTE: Using system only works with Webpack 2. Webpack 1 users should use the default.

replacement

{
  path: 'lazy',
  loadChildren: () => System.import('./lazy/lazy.module').then(function(module) {
    return module['LazyModule'];
  })
}

Loader options (AoT compilation)

aot: (default: false)

Enables replacement of the loadChildren string to load the Angular compiled factory file and factory class based on the provided file and class.

genDir (default: '')

In your tsconfig.json, if you set the genDir in the angularCompilerOptions to compile to a separate directory, this option needs to be set to the same value here.

AoT example

Example file structure (after an AOT build)

|-- compiled
   |-- src
      |-- app
|-- src
   |-- app
|-- tsconfig.json

tsconfig.json (Angular Compiler Options)

"angularCompilerOptions": {
  "genDir": "compiled",
  "skipMetadataEmit" : true
}

Webpack Configuration (TypeScript loaders)

loaders: [
  {
    test: /\.ts$/,
    loaders: [
      'awesome-typescript-loader',
      'angular-router-loader?aot=true&genDir=compiled'
    ]
  }
]

original

{
  path: 'lazy',
  loadChildren './lazy.module#LazyModule'
}

replacement

{
  path: 'lazy',
  loadChildren: () => new Promise(function (resolve) {
    (require as any).ensure([], function (require: any) {
      resolve(require('./lazy/lazy.module.ngfactory')['LazyModuleNgFactory']);
    });
  })
}

Lazy Loading Options

chunkName (require loader only)

Allows you to provide named chunks for code splitting.

original

{
  path: 'lazy',
  loadChildren './lazy.module#LazyModule?chunkName=MyChunk'
}

replacement

{
  path: 'lazy',
  loadChildren: () => new Promise(function (resolve) {
    (require as any).ensure([], function (require: any) {
      resolve(require('./lazy/lazy.module')['LazyModule']);
    }, 'MyChunk');
  })
}