gpt4 book ai didi

angular - 如何以编程方式扩展动态添加的 mat-expansion-panel?

转载 作者:行者123 更新时间:2023-12-03 21:19:07 24 4
gpt4 key购买 nike

我正在尝试使用 *ngFor 在 Mat-accordian 中显示多个 Mat-expansion-panel。我需要点击一个我能够做到的按钮来添加一个新的垫子扩展面板。我还需要在单击按钮时展开(打开)这个新添加的扩展面板,这是我无法实现的。请帮忙。

Stackblitz - https://stackblitz.com/edit/angular-fh5vu1-g6phe6?file=app%2Fexpansion-steps-example.ts

export class ExpansionStepsExample { 
items: number[] = [1,2,3];

AddNewRow() {
this.items.push(4);
}
}
<mat-accordion class="example-headers-align">
<mat-expansion-panel *ngFor="let item of items;">
<mat-expansion-panel-header>
<mat-panel-title> {{item}} </mat-panel-title>
</mat-expansion-panel-header>
{{item}}
</mat-expansion-panel>
</mat-accordion>
<button (click)="AddNewRow()" value="Add New"> Add New </button>

最佳答案

您可以访问 Material Expansion Panel 元素,并调用 open() 和 close() 方法。

import { Component, OnInit, ViewChild } from '@angular/core';
import { MatExpansionPanel } from '@angular/material';
...
@ViewChild(MatExpansionPanel, {static: true}) matExpansionPanelElement: MatExpansionPanel;
...
selectItem() {
this.matExpansionPanelElement.close(); //open()
}
<mat-accordion>
<mat-expansion-panel #matExpansionPanel>
...
</mat-expansion-panel>
</mat-accordion>

关于angular - 如何以编程方式扩展动态添加的 mat-expansion-panel?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/56532915/

24 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com