Angularmaterial排序表头在更改数据源后无法工作
创始人
2024-10-28 10:01:04
0

在更改数据源后,需要手动重新设置排序表头的数据源。这可以通过以下步骤实现:

  1. 在 HTML 模板中,找到包含排序表头的 mat-table 元素,将其绑定到模板引用变量中:

  2. 在组件类中,使用 ViewChild 装饰器和 @Input() 装饰器声明这个引用变量:

    @ViewChild('table') table: MatTable; @Input() dataSource: MatTableDataSource;

  3. 在更改数据源后,重新设置表头的数据源:

    this.dataSource = new MatTableDataSource(data); this.table.dataSource = this.dataSource;

  4. 现在,表头排序应该正常工作了。

完整的代码示例:

HTML 模板:


  
     Name 
     {{item.name}} 
  
  
     Age 
     {{item.age}} 
  
  
  

组件类:

import { Component, OnInit, ViewChild, Input } from '@angular/core';
import { MatTableDataSource, MatSort } from '@angular/material';

@Component({
  selector: 'app-table',
  templateUrl: './table.component.html',
  styleUrls: ['./table.component.scss']
})
export class TableComponent implements OnInit {
  displayedColumns: string[] = ['name', 'age'];
  dataSource: MatTableDataSource;

  @ViewChild(MatSort, { static: true }) sort: MatSort;
  @ViewChild('table') table: MatTable;
  @Input() data: any[];

  ngOnInit() {
    this.dataSource = new MatTableDataSource(this.data);
    this.dataSource.sort = this.sort;
    this.table.dataSource = this.dataSource;
  }

  ngOnChanges(changes) {
    if (changes.data) {
      this.dataSource = new MatTableDataSource(changes.data.currentValue);
      this.dataSource.sort = this.sort;
      this.table.dataSource = this.dataSource;
    }

相关内容

热门资讯

透视透视!hhpoker视频巡... 透视透视!hhpoker视频巡查真的假的,wepoker线上大神(透视)透视教程(有挂教程)-哔哩哔...
透视真的!德普之星辅助工具如何... 透视真的!德普之星辅助工具如何打开,hhpoker辅助靠谱吗(透视)专业教程(有挂分享)-哔哩哔哩暗...
透视好牌!xpoker怎么辅助... 透视好牌!xpoker怎么辅助,we-poker靠谱吗(透视)有挂教程(有挂辅助)-哔哩哔哩1、许多...
截至发稿!hh poker透视... 截至发稿!hh poker透视器下载,德普之星私人局辅助器(透视)解谜教程(有挂神器)-哔哩哔哩1、...
日前!wejoker辅助器怎么... 日前!wejoker辅助器怎么卖,wepoker辅助器安装包(透视)透视教程(有挂秘诀)-哔哩哔哩1...
据文件显示!pokeplus脚... 据文件显示!pokeplus脚本,wpk模拟器是什么(透视)科普教程(有挂猫腻)-哔哩哔哩1、全新机...
透视挂透视!pokemmo辅助... 透视挂透视!pokemmo辅助器脚本下载,wepoker透视脚本安卓(透视)关于教程(真的有挂)-哔...
推出新举措!WePoKer辅助... 推出新举措!WePoKer辅助器,pokerworld破解版下载(透视)科普教程(有挂助手)-哔哩哔...
截至目前!pokemmo手机版... 截至目前!pokemmo手机版脚本免费,wepoker分析(透视)揭露教程(有挂技术)-哔哩哔哩;运...
针对!红龙poker有辅助吗,... 针对!红龙poker有辅助吗,wepoker透视脚本安卓(透视)教你教程(存在有挂)-哔哩哔哩1、许...