这似乎是一个愚蠢的问题,但是在调查并进行了各种测试之后,我不明白为什么会发生这种情况。
我有一个发送按钮,应该在发送时显示一个微调器,然后返回不显示它。
<button (click)="sendCSV()" class="btn btn-primary btn-sm"><i class="fas fa-spinner fa-spin" [style.visibility] = "sendingEmails ? 'visible' : 'hidden'"></i> Send</button>
{{sendingEmails}}
我在按钮下方添加了 {{sendingEmails}} 以验证变量是否正确更改,并且确实如此。在我的组件中,我有一个最初为 false 的 sentEmails var,并且:
sendCSV() {
this.sendingEmails = true;
this.eventsService.sendGuestlistByEmail(this.eventId).subscribe(
res => {
this.sendingEmails = false;
console.log(res);
},
err => {
this.sendingEmails = false;
console.log("Error.");
}
);
}
问题是当我点击发送时,数据绑定会正确更新(假-真-假),但样式保持不变,就好像我从未点击过一样。
万一这很重要,我使用 Font Awesome 5 作为微调器。
我也试过
<i class="fas fa-spinner fa-spin" *ngIf="sendingEmails"></i>
这将导致每次我发送电子邮件时微调器都会增加,并且在第一次之后就不会真正消失。
知道为什么会这样吗?