UpgradeComponent
class
A helper class that allows an AngularJS component to be used from Angular.
class UpgradeComponent implements OnInit, OnChanges, DoCheck, OnDestroy {
  constructor(name: string, elementRef: ElementRef<any>, injector: Injector)
  ngOnInit()
  ngOnChanges(changes: SimpleChanges)
  ngDoCheck()
  ngOnDestroy()
}   Description
Part of the upgrade/static library for hybrid upgrade apps that support AOT compilation.
This helper class should be used as a base class for creating Angular directives that wrap AngularJS components that need to be "upgraded".
Constructor
| Create a new  | |||||||||
| 
 | 
| name | string | |
| elementRef | ElementRef | |
| injector | Injector | 
// This Angular directive will act as an interface to the "upgraded" AngularJS component
@Directive({selector: 'ng1-hero'})
export class Ng1HeroComponentWrapper extends UpgradeComponent {
  // The names of the input and output properties here must match the names of the
  // `<` and `&` bindings in the AngularJS component that is being wrapped
  @Input() hero!: Hero;
  @Output() onRemove!: EventEmitter<void>;
  constructor(elementRef: ElementRef, injector: Injector) {
    // We must pass the name of the directive as used by AngularJS to the super
    super('ng1Hero', elementRef, injector);
  }
} - The nameparameter should be the name of the AngularJS directive.
- The elementRefandinjectorparameters should be acquired from Angular by dependency injection into the base class constructor.
Methods
|   ngOnInit()    | 
|---|
| 
 | 
|   ngOnChanges()    | 
|---|
|   ngDoCheck()    | 
|---|
| 
 | 
|   ngOnDestroy()    | 
|---|
| 
 | 
Usage notes
Examples
Let's assume that you have an AngularJS component called ng1Hero that needs to be made available in Angular templates.
// This AngularJS component will be "upgraded" to be used in Angular
ng1AppModule.component('ng1Hero', {
  bindings: {hero: '<', onRemove: '&'},
  transclude: true,
  template: `<div class="title" ng-transclude></div>
             <h2>{{ $ctrl.hero.name }}</h2>
             <p>{{ $ctrl.hero.description }}</p>
             <button ng-click="$ctrl.onRemove()">Remove</button>`
}); We must create a Directive that will make this AngularJS component available inside Angular templates.
// This Angular directive will act as an interface to the "upgraded" AngularJS component
@Directive({selector: 'ng1-hero'})
export class Ng1HeroComponentWrapper extends UpgradeComponent {
  // The names of the input and output properties here must match the names of the
  // `<` and `&` bindings in the AngularJS component that is being wrapped
  @Input() hero!: Hero;
  @Output() onRemove!: EventEmitter<void>;
  constructor(elementRef: ElementRef, injector: Injector) {
    // We must pass the name of the directive as used by AngularJS to the super
    super('ng1Hero', elementRef, injector);
  }
} In this example you can see that we must derive from the UpgradeComponent base class but also provide an `@Directive` decorator. This is because the AOT compiler requires that this information is statically available at compile time.
Note that we must do the following:
- specify the directive's selector (ng1-hero)
- specify all inputs and outputs that the AngularJS component expects
- derive from UpgradeComponent
-  call the base class from the constructor, passing - the AngularJS name of the component (ng1Hero)
- the ElementRefandInjectorfor the component wrapper
 
- the AngularJS name of the component (
    © 2010–2020 Google, Inc.
Licensed under the Creative Commons Attribution License 4.0.
    https://v9.angular.io/api/upgrade/static/UpgradeComponent