How to access the nativeElement of a Component in Angular4?

前端 未结 3 1697
星月不相逢
星月不相逢 2020-12-16 09:31

I have two components and one with attribute selector. The child component is,

import { Component, OnInit, Input, El         


        
相关标签:
3条回答
  • 2020-12-16 09:51

    The problem is that if you define a template reference on the element that Angular views as a host element of the component, you will get a reference to the component instance. Here:

    <... chartContainer]="chartContainer" #chartContainer></div>
    

    chartContainer will point to the instance of the BarChartComponent and that is why nativeElement is undefined.

    To get elementRef of the host element, you don't need any bindings or lifecycle hooks, just inject the element into the constructor:

    export class BarChartComponent implements OnInit {
       constructor(element: ElementRef) {
            console.log(element.nativeElement);
       }
    
    0 讨论(0)
  • 2020-12-16 09:59

    If you need the ElementRef of a component, you can't use a template variable. If the element is a component, you'll get the component instance instead. A template variable only returns ElementRef for plain HTML elements.

    To get ElementRef of a component, you need to use @ViewChild()

    @ViewChild('chartContainer', { read: ElementRef }) myChartContainer:ElementRef;
    

    and then pass it along with

    [chartContainer]="myChartContainer"
    

    I would make the input a setter

     private _chartContainer:ElementRef;
     @Input() 
     set chartContainer(value: ElementRef) {
       this._chartContainer = value;
       console.log(this.chartContainer);
       console.log(this.chartContainer.nativeElement);
     }
    

    but ngOnInit works as well Plunker example

    0 讨论(0)
  • 2020-12-16 10:03

    In the first selector you have set '[app-bar-chart]' and it should be without square brachets. To pass the parent you should use:

     [chartContainer]="this"
    

    instead of:

     [chartContainer]="chartContainer"
    
    0 讨论(0)
提交回复
热议问题