4

Context Angular project
I have the following snippet:

export class OnlyNumberDirective {
  constructor(private _el: ElementRef,private renderer:Renderer2) {
  }
  @HostListener('input', ['$event']) onInputChange(e) {
    this.renderer.invokeElementMethod(this._el.nativeElement, 'dispatchEvent', [event]);
  }
}

it uses Renderer, but it is deprecated and now we have Renderer2?
What is the alternative to invokeElementMethod method in Renderer2?

Hakan Fıstık
  • 16,800
  • 14
  • 110
  • 131

2 Answers2

2

From the migration guide, it appears the following replacement should work

(this._el.nativeElement as any)['dispatchEvent'].apply(this._el.nativeElement, [event]);
ruth
  • 29,535
  • 4
  • 30
  • 57
1

try this one:

export class OnlyNumberDirective {
  constructor(private _el: ElementRef) {
  }
  @HostListener('input', ['$event']) onInputChange(e) {
    let event: Event = document.createEvent("Event");
    event.initEvent('input', true, true);
    Object.defineProperty(event, 'target', { value: this._el.nativeElement, enumerable: true });
    this._el.nativeElement.dispatchEvent(event);
  }
}