AngularMaterial表格动态垂直高度限制
创始人
2024-10-28 08:01:30
0

使用MatTableDataSource和ViewChild来动态计算表格高度并设置max-height属性。以下是代码示例:

HTML:


  ...

TypeScript:

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

@Component({
  selector: 'app-table-example',
  templateUrl: './table-example.component.html',
  styleUrls: ['./table-example.component.scss']
})
export class TableExampleComponent implements OnInit {
  @ViewChild('table') table: ElementRef;

  dataSource = new MatTableDataSource();
  tableHeight: string;

  ngOnInit(): void {
    this.dataSource.data = [{...}, {...}, ...];
    this.calculateTableHeight();
  }

  calculateTableHeight() {
    const tableElement = this.table.nativeElement;
    const headerEnd = tableElement.querySelector('.mat-header-row').getBoundingClientRect().bottom;
    const footerStart = tableElement.querySelector('.mat-footer-row').getBoundingClientRect().top;
    const height = footerStart - headerEnd;
    this.tableHeight = `${height}px`;
  }
}

在ngOnInit中设置数据源并调用calculateTableHeight来计算表格高度。calculateTableHeight中使用ElementRef和querySelector获取表格头和表格尾的坐标,并计算表格高度。最后将表格高度设置为max-height属性的值。

相关内容

热门资讯

第四分钟分享!新星游拼十辅助,... 第四分钟分享!新星游拼十辅助,竹间茶馆辅助(总是存在有挂)-哔哩哔哩运新星游拼十辅助辅助工具,进入游...
第三分钟教你!心悦游戏辅助,杭... 第三分钟教你!心悦游戏辅助,杭州边锋辅助软件(原来是真的挂)-哔哩哔哩进入游戏-大厅左侧-新手福利-...
四分钟详细!福建天天开心无限辅... 四分钟详细!福建天天开心无限辅助科技,上饶中至能操控吗(其实是有挂)-哔哩哔哩1、下载好福建天天开心...
第4分钟分享!功夫川麻bug,... 第4分钟分享!功夫川麻bug,人海大厅辅助插件(本来真的是有挂)-哔哩哔哩在进入人海大厅辅助插件辅助...
5分钟了解!随意玩正版透视,金... 5分钟了解!随意玩正版透视,金州水鱼脚本(一贯存在有挂)-哔哩哔哩1、随意玩正版透视系统规律教程、随...
三分钟教你!卡丁互娱辅助器,途... 三分钟教你!卡丁互娱辅助器,途游辅助软件网站(一贯真的有挂)-哔哩哔哩在进入途游辅助软件网站辅助挂后...
第七分钟曝光!奇迹陕西辅助器,... 第七分钟曝光!奇迹陕西辅助器,四川途游辅助软件(总是有挂)-哔哩哔哩1、四川途游辅助软件ai辅助优化...
3分钟普及!都莱大菠萝怎么包赢... 3分钟普及!都莱大菠萝怎么包赢,微信小程序辅助器(其实真的是有挂)-哔哩哔哩1、都莱大菠萝怎么包赢系...
八分钟科普!浙江游戏大厅脚本修... 八分钟科普!浙江游戏大厅脚本修改,九酷众游软件(总是有挂)-哔哩哔哩八分钟科普!浙江游戏大厅脚本修改...
两分钟专业!789大菠萝有辅助... 两分钟专业!789大菠萝有辅助科技吗,战神辅助器下载(一直真的是有挂)-哔哩哔哩1、全新机制【789...