how to get root viewContainerRef of angular2 aplication

前端 未结 2 1810
我在风中等你
我在风中等你 2021-01-14 16:18

loadNextToLocation now expects a ViewContainerRef, any ideas on how to get the root viewContainerRef of the application in a correct way?

thanks in advance.

相关标签:
2条回答
  • 2021-01-14 16:41

    OLD WAY: Angular 2.0.0-rc.3

    This is a total hack and is in no way the correct way to get the root ViewContainerRef, but I was unable to find an official way to do this. Since these are not public properties they can change at any time and this method would no longer work. This method still works as of 2.0.0-rc.3.

    class SomeComponent {
        constructor(private appRef: ApplicationRef) { }
        let viewRef: ViewContainerRef = appRef['_rootComponents'][0]['_hostElement'].vcRef;
    }
    

    There is also currently an open issue for this on GitHub: https://github.com/angular/angular/issues/9293

    UPDATE: Angular 2.4.2

    The above method won't work with the later versions of Angular (as of 2.4.2).

    The method I use now is this:

    In the root component pass the ViewContainerRef so you can reference it later:

    class AppComponent {
        constructor(public viewRef: ViewContainerRef) { }
    }
    

    And then in the component or service that you want to get the root ViewContainerRef:

    class SomeOtherComponent {
        constructor(private appRef: ApplicationRef) { }
    
        let viewRef = (appRef.components[0].instance as AppComponent).viewRef;
    }
    

    The above will bring in the instance of your root component, and since you injected the ViewContainerRef in the constructor (and made it public) you can now reference it directly.

    0 讨论(0)
  • 2021-01-14 16:44

    I haven't tried it with the root component myself yet but I assume it works the same as with other components:

    class AppComponent {
      constructor(private vcRef:ViewContainerRef) {}
    }
    
    0 讨论(0)
提交回复
热议问题