Невозможно получить Angular значений автозавершения материала - PullRequest
1 голос
/ 02 августа 2020

Я пытаюсь создать фильтр автозаполнения и из массива, и когда я пытаюсь его использовать, он отображается в нижнем регистре, теперь функция ниже - это мой код

<form class="example-form">
  <mat-form-field class="example-full-width">
    <input type="text"
           placeholder="Pick one"
           matInput
           [formControl]="myControl"
           [matAutocomplete]="auto">
    <mat-autocomplete #auto="matAutocomplete">
      <mat-option *ngFor="let option of filteredOptions | async" [value]="option">
        {{option.Address}}
      </mat-option>
    </mat-autocomplete>
  </mat-form-field>
</form>

.ts code:

 myControl = new FormControl();
  options:any [] = [
    
        {
            "Id": "SO5",
            "Address": "Wall Street. New York City"
           
        },
        {
            "Id": "65",
            "Address": "Wall Street. New York City"
        },
        {
            "buyerId": "63g",
            "Address": "Dallas"
        }

  ]
  filteredOptions: Observable<any[]>;

  ngOnInit() {
    this.filteredOptions = this.myControl.valueChanges
      .pipe(
        startWith(''),
        map(value => this._filter(value))
      );
  }

  private _filter(value:any):any[] {
    console.log(value);
    const filterValue = value.toLowerCase();

    return this.options.filter(option => option.toLowerCase().includes(filterValue));
  }
}

ниже - моя ссылка stackblitz https://stackblitz.com/edit/angular-ygzpcz

1 Ответ

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

options - массив объектов. Для объекта нет метода toLowerCase.

Вместо этого вы должны использовать option.Address:

return this.options.filter(option => option.Address.toLowerCase()
                                          ^^^^^^^^^

Кроме того, в случае объектов вы должны создать метод displayWith для сопоставления объекта до желаемого отображаемого значения:

html

<mat-autocomplete ... [displayWith]="displayWith">

ts

displayWith(item: any) {
  return item ? item.Address : ''
}

Разветвленный Stackblitz

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