【问题标题】:MatTable not rendering MatTableDataSource dataMatTable 不呈现 MatTableDataSource 数据
【发布时间】:2020-11-13 23:57:02
【问题描述】:

我正在创建一个保存服务器端分页数据的表。但是,当我尝试在 MatTable 中渲染它时,我的数据根本不显示。我记录了数据源,它通常会显示数据。这是代码:

data-table.component.html

<div class="card-body mt-3">
  <table mat-table [dataSource]="dataSource" class="mat-elevation-z8">

    <!-- Number Column -->
    <ng-container matColumnDef="tn">
      <th mat-header-cell *matHeaderCellDef> TICKET# </th>
      <td mat-cell *matCellDef="let element"> {{element.tn}} </td>
    </ng-container>

    <!-- Number Column -->
    <ng-container matColumnDef="title">
      <th mat-header-cell *matHeaderCellDef> TITLE </th>
      <td mat-cell *matCellDef="let element"> {{element.title}} </td>
    </ng-container>

    <!-- Number Column -->
    <ng-container matColumnDef="date">
      <th mat-header-cell *matHeaderCellDef> DATE </th>
      <td mat-cell *matCellDef="let element"> {{element.create_time}} </td>
    </ng-container>

    <!-- Number Column -->
    <ng-container matColumnDef="product">
      <th mat-header-cell *matHeaderCellDef> PRODUCT </th>
      <td mat-cell *matCellDef="let element"> {{element.product}} </td>
    </ng-container>

    <!-- Number Column -->
    <ng-container matColumnDef="daysFromRegistration">
      <th mat-header-cell *matHeaderCellDef> DAYS SINCE REGISTERED </th>
      <td mat-cell *matCellDef="let element"> {{element.daysFromRegistration}} </td>
    </ng-container>

    <!-- Number Column -->
    <ng-container matColumnDef="analysisDays">
      <th mat-header-cell *matHeaderCellDef> DAYS ANALYSED </th>
      <td mat-cell *matCellDef="let element"> {{element.analysisDays}} </td>
    </ng-container>

    <!-- Number Column -->
    <ng-container matColumnDef="developmentDays">
      <th mat-header-cell *matHeaderCellDef> DAYS IN DEVELOPMENT </th>
      <td mat-cell *matCellDef="let element"> {{element.developmentDays}} </td>
    </ng-container>

    <!-- Number Column -->
    <ng-container matColumnDef="waitOrResponseDays">
      <th mat-header-cell *matHeaderCellDef> DAYS IN WAITING STATE </th>
      <td mat-cell *matCellDef="let element"> {{element.waitOrResponseDays}} </td>
    </ng-container>

    <!-- Number Column -->
    <ng-container matColumnDef="slaDays">
      <th mat-header-cell *matHeaderCellDef> SLA# </th>
      <td mat-cell *matCellDef="let element"> {{element.slaDays}} </td>
    </ng-container>

    <!-- Number Column -->
    <ng-container matColumnDef="user">
      <th mat-header-cell *matHeaderCellDef> AGENT USERNAME </th>
      <td mat-cell *matCellDef="let element"> {{element.user}} </td>
    </ng-container>

    <tr mat-header-row *matHeaderRowDef="displayedColumns"></tr>
    <tr mat-row *matRowDef="let row; columns: displayedColumns;"></tr>
  </table>
  
  <mat-paginator [pageSizeOptions]="[5, 10, 25, 100]"></mat-paginator>
</div>

data-table.component.ts


import { Component, OnInit, ViewChild } from '@angular/core';
import { MatPaginator } from '@angular/material/paginator';
import { MatTableDataSource } from '@angular/material/table';
import { Ticket } from 'src/app/model/ticket';
import { TicketService } from 'src/app/services/ticket.service';

@Component({
  selector: 'data-table',
  templateUrl: './data-table.component.html',
  styleUrls: ['./data-table.component.css']
})
export class DataTableComponent implements OnInit {

  displayedColumns: string[] = ["tn", "title", "date", "product", "daysFromRegistration", "analysisDays", "developmentDays", "waitOrResponseDays", "slaDays", "user"];
  dataSource: MatTableDataSource<Ticket>;

  tickets: Ticket[];

  @ViewChild(MatPaginator) paginator: MatPaginator;

  constructor(private ticketService: TicketService) {}

  ngOnInit() {
      this.ticketService.findTickets(0, 25).subscribe(
        (tickets: Ticket[]) => {
          this.dataSource = new MatTableDataSource(tickets);
          console.log(this.dataSource);
        }
      )
  }
}

ticket.service.ts

import { HttpClient, HttpParams } from '@angular/common/http';
import { Injectable } from '@angular/core';
import { Observable } from 'rxjs';
import { Ticket } from '../model/ticket';

@Injectable({
  providedIn: 'root'
})
export class TicketService {

  private ticketUrl: string;

  constructor(private http: HttpClient) {
    this.ticketUrl = 'http://localhost:8080/tickets';
   }

  public findTickets(pageNumber=0, pageSize=10): Observable<Ticket[]> {

    return this.http.get<Ticket[]>(this.ticketUrl, {
      params: new HttpParams()
      .set('page', pageNumber.toString())
      .set('size', pageSize.toString())
    })
  }
}

console.log(dataSource) 数据正常填充且不为空

MatTableDataSource {_renderData: BehaviorSubject, _filter: BehaviorSubject, _internalPageChanges: Subject, _renderChangesSubscription: Subscriber, sortingDataAccessor: ƒ, …}
filterPredicate: (data, filter) => {…}
filteredData: {content: Array(24), pageable: {…}, totalElements: 32876, last: false, totalPages: 1316, …}
sortData: (data, sort) => {…}
sortingDataAccessor: (data, sortHeaderId) => {…}
_data: BehaviorSubject {_isScalar: false, observers: Array(1), closed: false, isStopped: false, hasError: false, …}
_filter: BehaviorSubject {_isScalar: false, observers: Array(1), closed: false, isStopped: false, hasError: false, …}
_internalPageChanges: Subject {_isScalar: false, observers: Array(0), closed: false, isStopped: false, hasError: false, …}
_renderChangesSubscription: Subscriber {closed: false, _parentOrParents: null, _subscriptions: Array(1), syncErrorValue: null, syncErrorThrown: false, …}
_renderData: BehaviorSubject {_isScalar: false, observers: Array(1), closed: false, isStopped: false, hasError: false, …}
data: (...)
filter: (...)
paginator: (...)
sort: (...)
__proto__: DataSource

console.log(tickets)

{content: Array(10), pageable: {…}, last: false, totalElements: 32878, totalPages: 3288, …}
content: (10) [{…}, {…}, {…}, {…}, {…}, {…}, {…}, {…}, {…}, {…}]
empty: false
first: true
last: false
number: 0
numberOfElements: 10
pageable: {sort: {…}, offset: 0, pageNumber: 0, pageSize: 10, unpaged: false, …}
size: 10
sort: {sorted: false, unsorted: true, empty: true}
totalElements: 32878
totalPages: 3288
__proto__: Object

【问题讨论】:

    标签: angular angular-material mat-table


    【解决方案1】:

    试试这个

     ngOnInit() {
          this.ticketService.findTickets(0, 25).subscribe(
            (tickets: Ticket[]) => {
              this.dataSource = new MatTableDataSource(tickets);
              this.SetTableProperties();
            }
          )
      }
    SetTableProperties() {
        this.dataSource.paginator = this.paginator;
      }
    

    【讨论】:

    • 不起作用。我认为这不是分页器组件的问题,因为我已经尝试过没有它
    • 能否提供角材质版本?它甚至没有呈现标题?
    • 如果您使用console.log(tickets),您还可以发布控制台显示的内容吗?
    • 我还没有实现标题。我在底部添加了工单的 console.log
    • 你有 console.log 数据源。试试控制台日志票。
    猜你喜欢
    • 2019-11-06
    • 1970-01-01
    • 1970-01-01
    • 2013-12-11
    • 2015-09-06
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    相关资源
    最近更新 更多