В моем приложении есть mat-form-field с mat- option.. Я хочу, чтобы открывался диалог, когда я выбираю элемент из mat-option. Вот мой код. Сейчас, когда я выбираю элемент, ничего не происходит. Что я должен делать?

HTML:

                <ng-container matColumnDef="Order">
                    <th mat-header-cell *matHeaderCellDef width="10%"> Sipariş No </th>
                    <td mat-cell *matCellDef="let row; let i = index">
                        <span *ngIf="EditIndex != i">{{row.Order?.Subject}}</span>
                        <mat-form-field floatLabel="never" *ngIf="EditIndex == i" class="w-100-p" style="min-width: 100px !important;">
                            <mat-select [(ngModel)]="row.Order" required name="Order"
                                (selectionChange)="updateProducts($event.value)" style="min-width: 100px !important;">
                                <mat-select-trigger>
                                    {{row?.Order?.Reference}}
                                </mat-select-trigger>
                                <mat-option *ngFor="let order of originalSupplierOrders" [value]="order">
                                    {{order.Reference + ' - ' + order.Subject}}
                                </mat-option>
                            </mat-select>
                        </mat-form-field>
                    </td>
                </ng-container>

TS:

openSelectedOrderProductList(prm) {
    const dialogRef = this._dialog.open(SelectedOrderProductListDialogComponent, {
        width: "700px",
        data: prm,
    });

    dialogRef.afterClosed().subscribe((result) => {
        //console.log(result);
    });
}
0
Hectic Platypus 9 Окт 2021 в 18:18

2 ответа

Лучший ответ

Если вы используете реактивные формы, я предлагаю вам использовать valueChanges, вы можете обратиться к этому ответу.

В противном случае вы можете использовать только событие selectionChange для <mat-select>

0
YogendraR 9 Окт 2021 в 16:21

Вам нужно вызвать selectionChange, чтобы открыть диалоговое окно. Добавьте функцию openSelectedOrderProductList () в (selectionChange).

HTML:

 <ng-container matColumnDef="Order">
  <th mat-header-cell *matHeaderCellDef width="10%"> Sipariş No </th>
  <td mat-cell *matCellDef="let row; let i = index">
      <span *ngIf="EditIndex != i">{{row.Order?.Subject}}</span>
      <mat-form-field floatLabel="never" *ngIf="EditIndex == i" class="w-100-p" style="min-width: 100px !important;">
          <mat-select [(ngModel)]="row.Order" required name="Order"
              (selectionChange)="updateProducts($event.value);openSelectedOrderProductListfunction()" style="min-width: 100px !important;">
              <mat-select-trigger>
                  {{row?.Order?.Reference}}
              </mat-select-trigger>
              <mat-option *ngFor="let order of originalSupplierOrders" [value]="order">
                  {{order.Reference + ' - ' + order.Subject}}
              </mat-option>
          </mat-select>
      </mat-form-field>
  </td>
1
Talha 9 Окт 2021 в 21:25