mirror of
https://github.com/angular/angular
synced 2026-05-24 09:28:37 +00:00
This introduces the `BrowserModule` to be used for long form
bootstrap and offline compile bootstrap:
```
@AppModule({
modules: [BrowserModule],
precompile: [MainComponent],
providers: […], // additional providers
directives: […], // additional platform directives
pipes: […] // additional platform pipes
})
class MyModule {
constructor(appRef: ApplicationRef) {
appRef.bootstrap(MainComponent);
}
}
// offline compile
import {bootstrapModuleFactory} from ‘@angular/platform-browser’;
bootstrapModuleFactory(MyModuleNgFactory);
// runtime compile long form
import {bootstrapModule} from ‘@angular/platform-browser-dynamic’;
bootstrapModule(MyModule);
```
The short form, `bootstrap(...)`, can now creates a module on the fly,
given `directives`, `pipes, `providers`, `precompile` and `modules`
properties.
Related changes:
- make `SanitizationService`, `SecurityContext` public in `@angular/core` so that the offline compiler can resolve the token
- move `AnimationDriver` to `platform-browser` and make it
public so that the offline compiler can resolve the token
BREAKING CHANGES:
- short form bootstrap does no longer allow
to inject compiler internals (i.e. everything
from `@angular/compiler). Inject `Compiler` instead.
To provide custom providers for the compiler,
create a custom compiler via `browserCompiler({providers: [...]})`
and pass that into the `bootstrap` method.
|
||
|---|---|---|
| .. | ||
| @angular/tsc-wrapped | ||
| analytics | ||
| broccoli | ||
| build | ||
| cjs-jasmine | ||
| code.angularjs.org | ||
| karma | ||
| npm | ||
| public_api_guard | ||
| travis | ||
| tree-shaking-test | ||
| tsc-watch | ||
| tslint | ||
| typings-test | ||
| check-environment.js | ||
| chromedriverpatch.js | ||
| jsconfig.json | ||
| tsconfig.json | ||
| types.d.ts | ||
| utils.inc | ||