Odnosi się do https://angular.io/docs/ts/latest/guide/displaying-data.html i stosu Jak sprawdzić pusty obiekt w szablonie Angular 2 za pomocą * ngJeśli nadal pojawia się błąd składni niezdefiniowany. Jeśli usunę warunek * ngIf, otrzymam wartości w teamMembers, jeśli wrzucę do niego jakąś wartość, aby uzyskać dostęp do wartości w teamMembers.
moim teamMember
obiektem jest [ ] array
próba sprawdzenia, czy tablica warunków jest pusta według rozmiaru.
Próby:
<div class="row" *ngIf="(teamMembers | json) != '{}'">
i
<div class="row" *ngIf="teamMembers.length > 0"> //Check length great than
throwing syntax error
<div class="col-md-12">
<h4>Team Members</h4>
<ul class="avatar" *ngFor="let member of teamMembers">
<li><a href=""><gravatar-image [size]="80" [email]="member.email"></gravatar-image></a></li>
</ul>
</div>
</div>
Składnik :
@Component({
selector: 'pbi-editor',
})
export class AppComponent implements OnInit {
teamMembers: User[];
Każda pomoc byłaby świetna.
angular
angular2-template
Karthigeyan Vellasamy
źródło
źródło
Odpowiedzi:
<div class="row" *ngIf="teamMembers?.length > 0">
Sprawdza najpierw, czy
teamMembers
ma wartość, a jeśliteamMembers
nie ma wartości, nie próbuje uzyskać dostępulength
do,undefined
ponieważ pierwsza część warunku już zawodzi.źródło
safe navigation operator
: angular.io/guide/template-syntax#safe-navigation-operatorMożesz użyć,
*ngIf="teamMembers != 0"
aby sprawdzić, czy dane są obecneźródło
Może trochę przesada, ale utworzona biblioteka ngx-if-empty-or-has-items sprawdza, czy obiekt, zbiór, mapa lub tablica nie są puste. Może to komuś pomoże. Ma taką samą funkcjonalność jak ngIf (wtedy, else i obsługiwana jest składnia „as”).
źródło
Możesz użyć
Bez
event.attendees?.length > 0
lub nawetevent.attendees?length != 0
Ponieważ
?.length
już zwracamy wartość logiczną .Jeśli w tablicy będzie coś, to wyświetli to, w przeciwnym razie nie.
źródło
Ten artykuł pomógł mi dużo zrozumieć, dlaczego nie działa dla mnie. Daje mi to lekcję, jak myśleć o ładowaniu strony internetowej i o tym, jak angular 2 oddziałuje jako oś czasu, a nie tylko do momentu, o którym myślę. Nie widziałem, żeby ktokolwiek wspominał o tym punkcie, więc ...
Powód, dla którego * ngIf jest potrzebny, ponieważ spróbuje sprawdzić długość tej zmiennej, zanim wydarzy się reszta rzeczy OnInit, i wyrzuci błąd „length undefined”. Dlatego właśnie dodajesz? ponieważ jeszcze nie istnieje, ale wkrótce będzie.
źródło