我正在创建一个DOM结构,并且只想在第一时间在某些可视组件中添加一些部分,并且不希望它们一次又一次地刷新,这是* ngIf的工作方式。这是为了避免绑定一次又一次地执行我知道一旦创建就永远不会改变的事情。换句话说,Angular1有::
运算符可以帮助实现这一点。
Angular2中是否有*ngIf
的一次性绑定?如果在其他问题中讨论过这个问题,请指出我的问题。
答案 0 :(得分:1)
您可以创建自己的结构指令,它将在初始页面加载时评估传递的表达式,并根据传递的条件值显示或不在DOM中显示模板,如下所示:
import { Directive, Input, TemplateRef, ViewContainerRef } from '@angular/core';
@Directive({ selector: '[customNgIf]' })
export class CustomNgIfDirective {
@Input("customNgIf") condition: boolean;
constructor(
private templateRef: TemplateRef<any>,
private viewContainer: ViewContainerRef) {
}
ngOnInit() {
if (condition) {
this.viewContainer.createEmbeddedView(this.templateRef);
} else {
this.viewContainer.clear();
}
}
}
您可以这样使用它:
<div *customNgIf="expression">
Test
</div>