Получить объект из DataSource Angular MatTable

У меня есть таблица данных материалов, и я получаю данные из запроса для ее отображения. Вот мой файл 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, которые могли бы это сделать.

Заранее спасибо.

Тестирование функциональных ngrx-эффектов в Angular 16 с помощью Jest
В системе управления состояниями ngrx, совместимой с Angular 16, появились функциональные эффекты. Это здорово и делает код определенно легче для...
Angular и React для вашего проекта веб-разработки?
Angular и React для вашего проекта веб-разработки?
Когда дело доходит до веб-разработки, выбор правильного front-end фреймворка имеет решающее значение. Angular и React - два самых популярных...
Эпизод 23/17: Twitter Space о будущем Angular, Tiny Conf
Эпизод 23/17: Twitter Space о будущем Angular, Tiny Conf
Мы провели Twitter Space, обсудив несколько проблем, связанных с последними дополнениями в Angular. Также прошла Angular Tiny Conf с 25 докладами.
Угловой продивер
Угловой продивер
Оригинал этой статьи на турецком языке. ChatGPT используется только для перевода на английский язык.
Мое недавнее углубление в Angular
Мое недавнее углубление в Angular
Недавно я провел некоторое время, изучая фреймворк Angular, и я хотел поделиться своим опытом со всеми вами. Как человек, который любит глубоко...
Освоение Observables и Subjects в Rxjs:
Освоение Observables и Subjects в Rxjs:
Давайте начнем с основ и постепенно перейдем к более продвинутым концепциям в RxJS в Angular
0
0
1 853
1
Перейти к ответу Данный вопрос помечен как решенный

Ответы 1

Ответ принят как подходящий

Вы всегда можете сохранить копию самых последних данных и раскрыть ее через общедоступное свойство. Вот так:

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, но я ценю разъяснения!

Michael 01.08.2018 15:00

Другие вопросы по теме