ปรับปรุง
เราสามารถสร้าง directive like *ngIf
และเรียกมันว่า*ngVar
NG-var.directive.ts
@Directive({
selector: '[ngVar]',
})
export class VarDirective {
@Input()
set ngVar(context: any) {
this.context.$implicit = this.context.ngVar = context;
this.updateView();
}
context: any = {};
constructor(private vcRef: ViewContainerRef, private templateRef: TemplateRef<any>) {}
updateView() {
this.vcRef.clear();
this.vcRef.createEmbeddedView(this.templateRef, this.context);
}
}
ด้วย*ngVar
คำสั่งนี้เราสามารถใช้ต่อไปนี้
<div *ngVar="false as variable">
<span>{{variable | json}}</span>
</div>
หรือ
<div *ngVar="false; let variable">
<span>{{variable | json}}</span>
</div>
หรือ
<div *ngVar="45 as variable">
<span>{{variable | json}}</span>
</div>
หรือ
<div *ngVar="{ x: 4 } as variable">
<span>{{variable | json}}</span>
</div>
ตัวอย่าง Plunker Angular4 ngVar
ดูสิ่งนี้ด้วย
คำตอบเดิม
เชิงมุม v4
1) div
+ ngIf
+let
<div *ngIf="{ a: 1, b: 2 }; let variable">
<span>{{variable.a}}</span>
<span>{{variable.b}}</span>
</div>
2) div
+ ngIf
+as
ดู
<div *ngIf="{ a: 1, b: 2, c: 3 + x } as variable">
<span>{{variable.a}}</span>
<span>{{variable.b}}</span>
<span>{{variable.c}}</span>
</div>
component.ts
export class AppComponent {
x = 5;
}
3) ถ้าคุณไม่ต้องการสร้างเสื้อคลุมเหมือนdiv
คุณสามารถใช้ng-container
ดู
<ng-container *ngIf="{ a: 1, b: 2, c: 3 + x } as variable">
<span>{{variable.a}}</span>
<span>{{variable.b}}</span>
<span>{{variable.c}}</span>
</ng-container>
ตามที่ @ Keith พูดถึงในความคิดเห็น
สิ่งนี้จะได้ผลในกรณีส่วนใหญ่ แต่มันไม่ได้เป็นวิธีการแก้ปัญหาทั่วไปเพราะมันขึ้นอยู่กับตัวแปรเป็นความจริง
ดูการอัปเดตสำหรับวิธีการอื่น