Mat-Table ничего не показывает, хотя данные регистрируются (console.log) - PullRequest
1 голос
/ 26 мая 2019

Я хочу использовать mat-table для отображения списка пользователей, вызванных из моей базы данных с помощью Spring RestAPI, но даже после нескольких уроков в таблице отображается только заголовок (имена столбцов), и когда я проверяю свою консоль показывает список пользователей.

Вот мой HTML-компонент:

<div class="container-scroller">
  <app-navbar></app-navbar>
  <div class="container-fluid page-body-wrapper">
    <app-sidebar></app-sidebar>
    <div class="main-panel">
      <div class="content-wrapper">
        <div class="row">
          <div class="col-lg-12 grid-margin stretch-card">
            <div class="card">
              <div class="card-body">
                <h4 class="card-title" style="font-weight: 600">Users List</h4>
                <div class="table-responsive">  
                  <table mat-table [dataSource]="dataSource">
                    <ng-container matColumnDef="id">
                      <th mat-header-cell *matHeaderCellDef> ID </th>
                      <td mat-cell *matCellDef="let element"> {{element.id}} </td>
                    </ng-container>

                    <ng-container matColumnDef="userName">
                      <th mat-header-cell *matHeaderCellDef> Username </th>
                      <td mat-cell *matCellDef="let element"> {{element.username}} </td>
                    </ng-container>

                    <ng-container matColumnDef="firstName">
                      <th mat-header-cell *matHeaderCellDef> firstName </th>
                      <td mat-cell *matCellDef="let element"> {{element.firstName}} </td>
                    </ng-container>

                    <ng-container matColumnDef="lastName">
                      <th mat-header-cell *matHeaderCellDef> Last Name </th>
                      <td mat-cell *matCellDef="let element"> {{element.LastName}} </td>
                    </ng-container>

                    <ng-container matColumnDef="email">
                      <th mat-header-cell *matHeaderCellDef> Email </th>
                      <td mat-cell *matCellDef="let element"> {{element.email}} </td>
                    </ng-container>

                    <ng-container matColumnDef="registeredDate">
                      <th mat-header-cell *matHeaderCellDef> Registered Date </th>
                      <td mat-cell *matCellDef="let element"> {{element.registeredDate | date: shortDate}} </td>
                    </ng-container>

                    <tr mat-header-row *matHeaderRowDef="displayedColumns"></tr>
                    <tr mat-row *matRowDef="let row; columns: displayedColumns;"></tr>
                  </table>              
                </div>
              </div>
            </div>
          </div>
        </div>
      </div>
    </div>
  </div>
</div>

.ts файл:

import { Component, OnInit } from '@angular/core';
import { ViewEncapsulation } from '@angular/core';
import { UserService } from '../user.service';
import { MatTableDataSource } from '@angular/material';
import { User } from '../user';

@Component({
selector: 'app-dashboard',
templateUrl: './dashboard.component.html',
styleUrls: ['../app.component.scss', './dashboard.component.scss'],
encapsulation: ViewEncapsulation.None
})
export class DashboardComponent implements OnInit {
  loginuser: any = {};
  user: User[] = [];
  displayedColumns: string[] = ['id', 'userName', 'firstName', 'lastName', 'email', 'registeredDate'];
  public datasource = new MatTableDataSource<User>();
  constructor(private service: UserService) {}

  ngOnInit() {
      this.loginuser = JSON.parse(localStorage.getItem('currentUser'));
      this.getALLUSERS(this.loginuser.token);
  }

  public getALLUSERS(token: any) {
      this.service.getAllUsers(token).subscribe(u => {
      this.datasource.filteredData = u as User[];
      console.log('datasource: ', this.datasource.filteredData);
  });
  }

  onClick(selectedItem) {
      console.log('selected item: ', selectedItem);
  }
}

Пользовательский интерфейс:

export interface User {
   id: number;
   username: string;
   firstname: string;
   lastname: string;
   email: string;
   registereddate: Date;
}

1 Ответ

0 голосов
/ 26 мая 2019

Вы должны обновить data вместо filteredData источника данных.

this.datasource.data = u;
Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...