- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
再见,
我正在使用 Angular 8,我需要一个包含可扩展行的主表,并且我需要查看每一行的详细信息。
我的实际问题是排序只适用于父表而不适用于子表。
这是我的 HTML 代码:
<table mat-table [dataSource]="dataSource" multiTemplateDataRows matSort #sorter1="MatSort">
<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="expandedDetail">
<td mat-cell *matCellDef="let element" [attr.colspan]="2">
<div>
<table mat-table [dataSource]="dataSource2" matSort #innerSorts="MatSort">
<ng-container matColumnDef="id">
<th mat-header-cell *matHeaderCellDef> ID </th>
<td mat-cell *matCellDef="let element"> {{ element.id }} </td>
</ng-container>
<tr mat-header-row *matHeaderRowDef="['id']"></tr>
<tr mat-row *matRowDef="let element; columns: ['id'];"></tr>
</table>
</div>
</td>
</ng-container>
<tr mat-header-row *matHeaderRowDef="['id']"></tr>
<tr mat-row *matRowDef="let element; columns: ['id'];"
class="example-element-row"
[class.example-expanded-row]="expandedElement === element"
(click)="clickRow(element)">
</tr>
<tr mat-row *matRowDef="let row; columns: ['expandedDetail']"></tr>
</table>
这是我的 TypeScript 代码:
imports ...
@Component({
selector: 'my-nested-tables',
styleUrls: ['my-nested-tables.css'],
templateUrl: 'my-nested-tables.html',
animations: [
trigger('detailExpand', [
state('collapsed', style({height: '0px', minHeight: '0'})),
state('expanded', style({height: '*'})),
transition('expanded <=> collapsed', animate('225ms cubic-bezier(0.4, 0.0, 0.2, 1)')),
]),
],
})
export class MyNestedTablesComponent {
@Input() element: Array<Element>;
@Input() element2: Array<Element>;
dataSource1: MatTableDataSource<Element>(this.element);
dataSource2: MatTableDataSource<Element>(this.element2);
expandedElement: Element;
@ViewChild("sorter1", {static:true}) sorter1: MatSort;
@ViewChildren("innerTables") tables: QueryList<MatTable<Element>>
@ViewChildren("innerSorts") innerSorts: QueryList<MatSort>;
constructor(private cd: ChangeDetectorRef) { }
ngOnInit() {
this.dataSource.sort = sorter1;
}
ngOnChanges(change: SimpleChanges) {
this.dataSource1.data = this.element;
this.dataSource2.data = this.element2;
}
clickRow(element: Element) : void {
this.expandedElement = this.expandedElement === element ? null : element;
this.onLoadMyNestedElement.emit(this.expandedElement.id); // This is a event that update the element2 property (HTTP request).
this.cd.detectChanges();
this.tables.forEach((table, index) => (table.dataSource as MatTableDataSource<Element>).sort = this.innerSorts.toArray()[index]);
}
}
export class Element {
public id: number;
}
你能帮帮我吗?
感谢米勒!
最佳答案
Material 表可能很复杂且难以连接,尤其是在排序和过滤方面。
有助于简化事情的方法是将内部表分解为一个单独的组件,并将引用添加到父表中。
这还具有可单独测试的好处。尝试以下设置(我无法验证它是否有效,但这将是一个好的开始)
main-table.component.ts
<inner-table [data]="element.data"></inner-table>
inner-table.component.ts
import { MatTableDataSource, MatSort } from '@angular/material';
import { Component, Input, ViewChild } from '@angular/core';
@Component({
selector: "inner-table",
template: `
<table mat-table [dataSource]="dataSource" matSort>
<ng-container matColumnDef="id">
<th mat-header-cell *matHeaderCellDef mat-sort-header>ID</th>
<td mat-cell *matCellDef="let element">{{ element.id }}</td>
</ng-container>
<tr mat-header-row *matHeaderRowDef="['id']"></tr>
<tr mat-row *matRowDef="let element; columns: ['id']"></tr>
</table>
`
})
export class InnerTableComponent {
@Input()
set data(newData: []) {
this.dataSource.data = newData;
}
dataSource: MatTableDataSource<Element>;
@ViewChild(MatSort, {static: false}) sort: MatSort;
ngOnInit() {
this.dataSource = new MatTableDataSource();
this.dataSource.sort = this.sort;
}
}
我还制作了自己的角度 Material 表,名为 ngx-auto-table要帮助处理数据表,请查看它可能对您有所帮助。
关于html - 我怎样才能有嵌套的 mat-table sortables?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/60987161/
我已经彻底搜索过,但没有找到直接的答案。 将 opencv 矩阵 (cv::Mat) 作为参数传递给函数,我们传递的是智能指针。我们对函数内部的输入矩阵所做的任何更改也会改变函数范围之外的矩阵。 我读
是否可以有一个垫子分隔线(一条水平线分隔两个垫子选项)? 我试过: Cars Volvo Saab Mercedes Audi
使用的浏览器 - Chrome 67.0.3396.99 我创建了一个 DialogsModule它有一个组件 ConfirmDialog.component.ts使用以下模板 confirm-dia
我正在尝试使用 mat-toolbar 但出现错误: mat-menu.component.html: Responsive Navigation Menu I
我正在创建 angular 7 网络应用程序,并使用一个 mat-select 下拉菜单和一个 mat-paginator。现在我隐藏 mat-select 向下箭头。 Here is the mat
在我的应用程序中,我有一个通过引用接收 cv::Mat 对象的函数。这是函数的声明: void getChains(cv::Mat &img,std::vector &chains,cv::
我使用了独立的 EMA (1.5.0) 和 eclipse 插件(在 eclipse 4.5 中)来分析我的堆转储。 我想查看任何无法访问的对象信息,我已尝试在我的首选项和命令行选项 -keep_un
我是 flex 的新手,我的垫子 table 做得很好。 不幸的是,我的标题没有遵循我的单元格宽度。 这是我的结果的图片。 如您所见,我的标题与我的单元格不对齐。 这是我的 CSS 代码,就像我说我是
我试图在我的 Material 表上使用 mat-sort 和 mat-paginator,但似乎不起作用。 Table 确实获取了 dataSource.data 中的数据,它也显示在 mat-ta
我试图在我的 Material 表上使用 mat-sort 和 mat-paginator,但似乎不起作用。 Table 确实获取了 dataSource.data 中的数据,它也显示在 mat-ta
我想在每个 mat-option 文本上设置悬停样式,我希望文本显示在 mat-option 之外。为了实现这一点,我应用了非常高的 z-index 值,但没有任何改变。我尝试将 z-index 添加
默认情况下 mat-drawer-container/mat-sidenav-container 和 mat-drawer/mat-sidenav 高度基于 mat-drawer-cont
在 mat-card-header 中提供图像头像通过 mat-card-avatar 得到很好的支持. 在许多用例中,我们希望使用图标而不是图像作为卡片的“头像”。 有没有一种简单的方法可以用图标替
我想要一个包含 2 列的网格列表,并且在这些列中我想要 2 个垂直堆叠的复选框。 我看过 this question 这确实有点 工作,但我想知道是否有更简洁的方法解决这个问题,因为我必须使用大量的
更新:stackbliz https://angular-2wqf4b.stackblitz.io 我正在构建一个比较屏幕,我们可以在其中比较两个项目。我试图将这两项显示为两个 mat-cards里
试图模仿 Material guide 的外观,我无法让工具栏的阴影呈现在 mat-sidenav-container 元素之上: 显示工具栏和 sidenav 的页面,但投影不可见: 单独显示工具栏
请注意,分页/排序无法正常工作。分页不显示它显示的元素数量并且排序不起作用,但是如果您删除 html 文件中的行 *ngIf="dataSource?.filteredData.length > 0"
这个问题在这里已经有了答案: 关闭 10 年前。 Possible Duplicate: Proper stack and heap usage in C++? Heap vs Stack allo
单击每个单选按钮时,我需要为每个垫卡添加背景。背景应仅适用于与单击的垫单选按钮对应的垫卡。
Mat a = (Mat_(3,3) = 2 int dims; //! the number of rows and columns or (-1, -1) when the arr
我是一名优秀的程序员,十分优秀!