У меня есть таблица данных материалов, и я получаю данные из запроса для ее отображения. Вот мой файл transaction-history.component.ts:
import { Component, OnInit } from '@angular/core';
import { Transaction } from '../models/transaction';
import { TransactionService } from '../services/transaction.service';
import { DataSource } from '@angular/cdk/table';
import { Observable } from 'rxjs';
@Component({
selector: 'app-transaction-history',
templateUrl: './transaction-history.component.html',
styleUrls: ['./transaction-history.component.css']
})
export class TransactionHistoryComponent implements OnInit {
dataSource = new TransactionDataSource(this.transactionService);
displayedColumns = ['id', 'cust', 'mgrName', 'dept', 'timestamp'];
constructor(public transactionService: TransactionService) { }
ngOnInit() {
}
}
export class TransactionDataSource extends DataSource<any>{
constructor(private transactionService: TransactionService) {
super();
}
connect(): Observable<Transaction[]> {
return this.transactionService.getUploaded();
}
disconnect() { }
}
Это идеально отображает данные. Но теперь я хочу получить объекты Transaction, которые отображаются в каждой строке. Прямо сейчас dataSource получает список транзакций, но как я могу получить доступ к этому списку? Я не нашел никаких методов в объекте dataSource, которые могли бы это сделать.
Заранее спасибо.





Вы всегда можете сохранить копию самых последних данных и раскрыть ее через общедоступное свойство. Вот так:
export class TransactionDataSource extends DataSource<any>{
public data: Transaction[];
constructor(private transactionService: TransactionService) {
super();
}
connect(): Observable<Transaction[]> {
return this.transactionService.getUploaded().pipe(
tap((data) => this.data = data),
);
}
disconnect() { }
}
Одним из недостатков этого является то, что изменения свойства данных не будут отражены в таблице.
К сожалению, вы не можете напрямую подключиться к запросу, а также иметь возможность вносить изменения в данные, которые отражаются в таблице с помощью angular, но я ценю разъяснения!