downgradeModule
A helper function for creating an AngularJS module that can bootstrap an Angular module
"on-demand" (possibly lazily) when a downgraded component needs to be
instantiated.
function downgradeModule<T>(moduleOrBootstrapFn: Type<T> | ((extraProviders: StaticProvider[]) => Promise<NgModuleRef<T>>)): string;A helper function for creating an AngularJS module that can bootstrap an Angular module
"on-demand" (possibly lazily) when a downgraded component needs to be
instantiated.
Part of the upgrade/static library for hybrid upgrade apps that support AOT compilation.
It allows loading/bootstrapping the Angular part of a hybrid application lazily and not having to pay the cost up-front. For example, you can have an AngularJS application that uses Angular for specific routes and only instantiate the Angular modules if/when the user visits one of these routes.
The Angular module will be bootstrapped once (when requested for the first time) and the same reference will be used from that point onwards.
downgradeModule() requires either an NgModuleFactory, NgModule class or a function:
- NgModuleFactory: If you pass an- NgModuleFactory, it will be used to instantiate a module using- platformBrowser's- bootstrapModuleFactory(). NOTE: this type of the argument is deprecated. Please either provide an- NgModuleclass or a bootstrap function instead.
- NgModuleclass: If you pass an NgModule class, it will be used to instantiate a module using- platformBrowser's- bootstrapModule().
- Function: If you pass a function, it is expected to return a promise resolving to an- NgModuleRef. The function is called with an array of extra- Providersthat are expected to be available from the returned- NgModuleRef's- Injector.
downgradeModule() returns the name of the created AngularJS wrapper module. You can use it to
declare a dependency in your main AngularJS module.
{@example upgrade/static/ts/lite/module.ts region="basic-how-to"}
For more details on how to use downgradeModule() see
Upgrading for Performance.
stringfunction downgradeModule<T>(moduleOrBootstrapFn: NgModuleFactory<T>): string;A helper function for creating an AngularJS module that can bootstrap an Angular module
"on-demand" (possibly lazily) when a downgraded component needs to be
instantiated.
Part of the upgrade/static library for hybrid upgrade apps that support AOT compilation.
It allows loading/bootstrapping the Angular part of a hybrid application lazily and not having to pay the cost up-front. For example, you can have an AngularJS application that uses Angular for specific routes and only instantiate the Angular modules if/when the user visits one of these routes.
The Angular module will be bootstrapped once (when requested for the first time) and the same reference will be used from that point onwards.
downgradeModule() requires either an NgModuleFactory, NgModule class or a function:
- NgModuleFactory: If you pass an- NgModuleFactory, it will be used to instantiate a module using- platformBrowser's- bootstrapModuleFactory(). NOTE: this type of the argument is deprecated. Please either provide an- NgModuleclass or a bootstrap function instead.
- NgModuleclass: If you pass an NgModule class, it will be used to instantiate a module using- platformBrowser's- bootstrapModule().
- Function: If you pass a function, it is expected to return a promise resolving to an- NgModuleRef. The function is called with an array of extra- Providersthat are expected to be available from the returned- NgModuleRef's- Injector.
downgradeModule() returns the name of the created AngularJS wrapper module. You can use it to
declare a dependency in your main AngularJS module.
{@example upgrade/static/ts/lite/module.ts region="basic-how-to"}
For more details on how to use downgradeModule() see
Upgrading for Performance.
stringDescription
A helper function for creating an AngularJS module that can bootstrap an Angular module
"on-demand" (possibly lazily) when a downgraded component needs to be
instantiated.
Part of the upgrade/static library for hybrid upgrade apps that support AOT compilation.
It allows loading/bootstrapping the Angular part of a hybrid application lazily and not having to pay the cost up-front. For example, you can have an AngularJS application that uses Angular for specific routes and only instantiate the Angular modules if/when the user visits one of these routes.
The Angular module will be bootstrapped once (when requested for the first time) and the same reference will be used from that point onwards.
downgradeModule() requires either an NgModuleFactory, NgModule class or a function:
- NgModuleFactory: If you pass an- NgModuleFactory, it will be used to instantiate a module using- platformBrowser's- bootstrapModuleFactory(). NOTE: this type of the argument is deprecated. Please either provide an- NgModuleclass or a bootstrap function instead.
- NgModuleclass: If you pass an NgModule class, it will be used to instantiate a module using- platformBrowser's- bootstrapModule().
- Function: If you pass a function, it is expected to return a promise resolving to an- NgModuleRef. The function is called with an array of extra- Providersthat are expected to be available from the returned- NgModuleRef's- Injector.
downgradeModule() returns the name of the created AngularJS wrapper module. You can use it to
declare a dependency in your main AngularJS module.
import {platformBrowserDynamic} from '@angular/platform-browser-dynamic';import {downgradeComponent, downgradeModule, UpgradeComponent} from '@angular/upgrade/static';// The function that will bootstrap the Angular module (when/if necessary).// (This would be omitted if we provided an `NgModuleFactory` directly.)const ng2BootstrapFn = (extraProviders: StaticProvider[]) => platformBrowserDynamic(extraProviders).bootstrapModule(MyLazyAngularModule);// This AngularJS module represents the AngularJS pieces of the application.const myMainAngularJsModule = angular.module('myMainAngularJsModule', [ // We declare a dependency on the "downgraded" Angular module. downgradeModule(ng2BootstrapFn), // or // downgradeModule(MyLazyAngularModuleFactory)]);
For more details on how to use downgradeModule() see
Upgrading for Performance.
Usage Notes
Apart from UpgradeModule, you can use the rest of the upgrade/static helpers as usual to
build a hybrid application. Note that the Angular pieces (e.g. downgraded services) will not be
available until the downgraded module has been bootstrapped, i.e. by instantiating a downgraded
component.
  You cannot use downgradeModule() and UpgradeModule in the same hybrid application.
  Use one or the other.
        
          Differences with UpgradeModule
        
      
    Besides their different API, there are two important internal differences between
downgradeModule() and UpgradeModule that affect the behavior of hybrid applications:
- Unlike UpgradeModule,downgradeModule()does not bootstrap the main AngularJS module inside theAngular zone.
- Unlike UpgradeModule,downgradeModule()does not automatically run a $digest() when changes are detected in the Angular part of the application.
What this means is that applications using UpgradeModule will run change detection more
frequently in order to ensure that both frameworks are properly notified about possible changes.
This will inevitably result in more change detection runs than necessary.
downgradeModule(), on the other side, does not try to tie the two change detection systems as
tightly, restricting the explicit change detection runs only to cases where it knows it is
necessary (e.g. when the inputs of a downgraded component change). This improves performance,
especially in change-detection-heavy applications, but leaves it up to the developer to manually
notify each framework as needed.
For a more detailed discussion of the differences and their implications, see Upgrading for Performance.
You can manually trigger a change detection run in AngularJS using scope.$apply(...) or $rootScope.$digest().
  You can manually trigger a change detection run in Angular using *   ngZone.run(...).
Downgrading multiple modules
It is possible to downgrade multiple modules and include them in an AngularJS application. In that case, each downgraded module will be bootstrapped when an associated downgraded component or injectable needs to be instantiated.
Things to keep in mind, when downgrading multiple modules:
- Each downgraded component/injectable needs to be explicitly associated with a downgraded module. See - downgradeComponent()and- downgradeInjectable()for more details.
- If you want some injectables to be shared among all downgraded modules, you can provide them as - StaticProviders, when creating the- PlatformRef(e.g. via- platformBrowseror- platformBrowserDynamic).
- When using - bootstrapModule()- bootstrapModuleFactory()- "root"(via- providedInIf this is not your intention, you can have a shared module (that will act as act as the "root" module) and create all downgraded modules using that module's injector:
let rootInjectorPromise: Promise
const downgradedNg2AModule = downgradeModule(async (extraProviders: StaticProvider[]) => { const rootInjector = await getRootInjector(extraProviders); const moduleAFactory = await rootInjector.get(Compiler).compileModuleAsync(Ng2AModule); return moduleAFactory.create(rootInjector); }); const downgradedNg2BModule = downgradeModule(async (extraProviders: StaticProvider[]) => { const rootInjector = await getRootInjector(extraProviders); const moduleBFactory = await rootInjector.get(Compiler).compileModuleAsync(Ng2BModule); return moduleBFactory.create(rootInjector); }); const appModule = angular .module('exampleAppModule', [downgradedNg2AModule, downgradedNg2BModule, downgradedNg2CModule]) ```