问题
@ViewChild
显示模板中的相应元素后最优雅的获取方式是什么?
下面是一个例子。Plunker 也可用。
组件.模板.html:
<div id="layout" *ngIf="display">
<div #contentPlaceholder></div>
</div>
组件.component.ts:
export class AppComponent {
display = false;
@ViewChild('contentPlaceholder', { read: ViewContainerRef }) viewContainerRef;
show() {
this.display = true;
console.log(this.viewContainerRef); // undefined
setTimeout(() => {
console.log(this.viewContainerRef); // OK
}, 1);
}
}
我有一个默认隐藏其内容的组件。当有人调用show()
方法时,它变得可见。但是,在 Angular 2 更改检测完成之前,我无法参考viewContainerRef
. 我通常将所有必需的操作包装成setTimeout(()=>{},1)
如上所示。有没有更正确的方法?
我知道有一个选项ngAfterViewChecked
,但它会导致太多无用的调用。