ngIf не срабатывает при изменении значения
У меня есть простой коврик, который должен срабатывать при isLoading
является true
, Переменная изменяется по назначению, но циновка не видна. Видно только если я поменяю isLoading
всегда быть true
,
Я что-то пропустил? Заранее спасибо!
app.component.ts:
import { Component, OnDestroy } from '@angular/core';
import { UtilityService } from './services/utility.service';
@Component({
selector: 'app-root',
templateUrl: './app.component.html',
styleUrls: ['./app.component.scss']
})
export class AppComponent implements OnDestroy {
title = 'cpt';
isLoading = true;
subscription;
constructor(private utilityService: UtilityService) {
this.subscription = this.utilityService.getIsLoadingObservable().subscribe(isLoading => {
this.isLoading = isLoading;
});
}
ngOnDestroy() {
this.subscription.unsubscribe();
}
}
app.component.html:
<div class="loading-shade" *ngIf="isLoading">
<mat-spinner></mat-spinner>
</div>
<app-router></app-router>
utility.service.ts:
import { Injectable } from '@angular/core';
import { BehaviorSubject, Observable } from 'rxjs';
@Injectable({
providedIn: 'root'
})
export class UtilityService {
public isLoading: BehaviorSubject<boolean> = new BehaviorSubject(false);
constructor() { }
getIsLoadingObservable(): Observable<boolean> {
return this.isLoading.asObservable();
}
async setIsLoading(val: boolean) {
await this.isLoading.next(val);
}
}
РЕДАКТИРОВАТЬ Добавление компонента, который запускает функцию установки: start.component.ts:
import { Component } from '@angular/core';
import { NodeService } from '../../services/node.service';
import { UtilityService } from '../../services/utility.service';
@Component({
selector: 'app-start',
templateUrl: './start.component.html',
styleUrls: ['./start.component.scss']
})
export class StartComponent {
isLoading = false;
constructor(
private nodeService: NodeService,
private utilityService: UtilityService) {}
async selectNode(val: string) {
await this.utilityService.setIsLoading(true);
if (val === 'bank') {
await this.nodeService.setNode('http://localhost:8091');
} else if (val === 'auditor') {
await this.nodeService.setNode('http://localhost:8092');
} else if (val === 'spv') {
await this.nodeService.setNode('http://localhost:8093');
} else {
await this.nodeService.setNode('http://localhost:8094');
}
await this.utilityService.setIsLoading(false);
}
}
2 ответа
Решение
Хорошо, это не имеет ничего общего с ngIf, извините. Проблема заключалась в setNode()
функция, где вторая setIsLoading()
Вызов (обратно в ложь) производится сразу после первого, потому что await
не работает, как ожидалось.
Спасибо всем, кто пытался помочь!
Ваш код в порядке и работает здесь, как и ожидалось. Вы должны вручную запустить setIsLoading()
метод, как это:
export class AppComponent implements OnDestroy {
title = 'cpt';
isLoading = true;
subscription;
test = false;
constructor(private utilityService: UtilityService) {
this.subscription = this.utilityService
.getIsLoadingObservable()
.subscribe(isLoading => {
this.isLoading = isLoading;
});
setInterval(() => {
this.test = !this.test;
this.utilityService.setIsLoading(this.test);
}, 2000);
}
ngOnDestroy() {
this.subscription.unsubscribe();
}
}