Я использовал приведенный ниже код TS для загрузки данных в таблицу Bootstrap, и я хотел поэкспериментировать с таблицей Angular Material Data после небольшого подъема. В этот момент я просто мог загрузить заголовок таблицы, но не смог найти, как сделать так, чтобы данные отображались. Ошибка не выдана, журнал консоли, который я вставил, говорит:
Наблюдаемый -> MapOperator -> thisArg: undefined
import { Component, OnInit } from '@angular/core';
import { MatTableDataSource } from '@angular/material';
import { map } from 'rxjs/operators';
import { Observable } from 'rxjs';
import { AngularFirestore } from '@angular/fire/firestore';
@Component({
selector: 'app-tasks',
templateUrl: './tasks.component.html',
styleUrls: ['./tasks.component.scss']
})
export class TasksComponent implements OnInit {
tasks: Observable<any[]>;
displayedColumns = ['description', 'note'];
dataSource: MatTableDataSource<Tasks>;
constructor(private db: AngularFirestore) {}
ngOnInit() {
this.tasks = this.db
.collection('tasks')
.snapshotChanges()
.pipe(
map(actions => {
return actions.map(a => {
const data = a.payload.doc.data() as Tasks;
const id = a.payload.doc.id;
return { id, ...data };
});
})
);
console.log(this.tasks);
return this.tasks;
}
}
export interface Tasks {
description: string;
note: string;
}
Вот мой HTML:
<mat-table #table [dataSource]="dataSource">
<ng-container matColumnDef="description">
<mat-header-cell *matHeaderCellDef> description </mat-header-cell>
<mat-cell *matCellDef="let task">{{task.description}}</mat-cell>
</ng-container>
<ng-container matColumnDef="note">
<mat-header-cell *matHeaderCellDef> note </mat-header-cell>
<mat-cell *matCellDef="let task">{{task.note}}</mat-cell>
</ng-container>
<mat-header-row *matHeaderRowDef="displayedColumns"></mat-header-row>
<mat-row *matRowDef="let row; columns: displayedColumns;"></mat-row>
</mat-table>
Я использую Angular 7 с текущими версиями пакетов, а база данных содержит записи, так что я здесь не так делаю?