在模板中显示相应的元素后,最优雅的方法是什么?
下面是一个例子。还有砰砰作响可用。
Component.template.html:
<div id="layout" *ngIf="display">
<div #contentPlaceholder></div>
</div>
Component.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
有一个选项,但它会导致太多无用的调用。