1

这似乎是一个愚蠢的问题,但是在调查并进行了各种测试之后,我不明白为什么会发生这种情况。

我有一个发送按钮,应该在发送时显示一个微调器,然后返回不显示它。

<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>

这将导致每次我发送电子邮件时微调器都会增加,并且在第一次之后就不会真正消失。

知道为什么会这样吗?

4

2 回答 2

2

谢谢大家的意见和建议。

事实证明,问题不在于 Angular,而在于 FontAwesome。我最近升级到使用 SVG 而不是 CSS 的 FontAwesome 5。因此,FontAwesome 将 my<i>变成了 SVG,因此无法正确更新。

这是一个非常愚蠢的问题,但对于习惯了旧 FontAwesome 的人来说可能会出现,所以我想留下我的“解决方案”。

就像这样做一样简单:

<span [style.visibility] = "sendingEmails ? 'visible' : 'hidden'">
    <i class="fas fa-spinner fa-spin"></i>
</span>
于 2018-04-24T18:38:58.987 回答
1

尝试使用 ChangeDetectorRef.detectChanges() 在组件上运行更改检测

  constructor(private changeD: ChangeDetectorRef) {}

  sendCSV() {
   this.sendingEmails = true;
    this.eventsService.sendGuestlistByEmail(this.eventId).subscribe(
        res => {
            this.sendingEmails = false;
            this.changeD.detectChanges();
            console.log(res);
        }, 
        err => {
            this.sendingEmails = false;
            console.log("Error.");
        }
    );
  }
于 2018-04-23T23:21:21.190 回答