Почему mat-autocomplete не отображает найденные параметры? - PullRequest
0 голосов
/ 04 августа 2020

Это форма, которую я использую:

<form [formGroup]="searchForm" id="searchForm">
   <mat-form-field>
      <input
      matInput
      type="text"
      name="awesome"
      id="awesome"
      [formControl] = "formCtrl"
      [matAutocomplete] = "auto"
      value="{{ awesomeText }}"
      [matAutocomplete]="auto">
      <mat-autocomplete #auto = "matAutocomplete">
         <mat-option *ngFor = "let res of result | async" [value] = "res">
         {{res}}
         </mat-option>
      </mat-autocomplete>
   </mat-form-field>
</form>

И это внутри constructor():

this.formCtrl = new FormControl();
this.formCtrl.valueChanges.subscribe((newValue) => {
    this.result = this.find(newValue);
    console.log('yes');
});

yes печатается, поэтому я знаю, что это работает, но mat-autocomplete ничего не показывает. Переменная result также обновляется, поскольку я вижу, как она печатается на консоли. Я не могу понять, почему искомые значения не отображаются.

Буду признателен за любую помощь!

Редактировать

Это find() метод:

find(val: string): string[] {
    const matchFound = [];

    for (let i = 0; i < dataJson.length; i++) {
        if (dataJson[i].text.toLowerCase().startsWith(val) || dataJson[i].text.startsWith(val)) {
            matchFound.push(dataJson[i].text);
        }
    }

    console.log('matches ' + matchFound);
    return matchFound;
}

1 Ответ

0 голосов
/ 04 августа 2020

Вы должны присвоить Observable строкового массива this.result. Но вы назначаете обычный строковый массив. async pipe работает с наблюдаемым, а не с обычным массивом. А в шаблоне ниже необходимо изменить

From

<mat-option *ngFor="let res of result | async" [value]="res">{{res}}</mat-option>

To

<mat-option *ngFor="let res of result | async" [value]="res.text">{{res.text}}</mat-option>

Typescript изменения

ngOnInit() {
  this.result = this.myControl.valueChanges.pipe(
    startWith(""),
    map(value => this.find(value))
  );
}

find(val: string): {
  id: number,
  text: string
}[] {
  const matchFound: {
    id: number,
    text: string
  }[] = [];

  for (let i = 0; i < this.dataJson.length; i++) {
    if (
      this.dataJson[i].text.toLowerCase().startsWith(val) ||
      this.dataJson[i].text.startsWith(val)
    ) {
      matchFound.push(this.dataJson[i]);
    }
  }

  console.log("matches " + matchFound);
  return matchFound;
}

Рабочий stackblitz

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...