web-dev-qa-db-ja.com

AutoComplete Material2で[displayWith]を使用して表示する方法

APIからのarrayがあり、これをフィルタリングするために Material2#AutoComplete を使用しています...これまでのところ機能していますが、binded値の代わりに別のpropertyoption

displayWith を使用する必要があることはわかっていますが、期待どおりに機能していません。 [displayWith]="displayFn.bind(this)">として呼び出される関数は、単にidを返します。どのようにして完全なオブジェクトを取得し、name on関数を返すことができますか。

ところで、私はまだFormControlにバインドされたidを持ちたいです。

いくつかのコード:

Component:

export class AutocompleteOverviewExample {
  stateCtrl: FormControl;
  filteredStates: any;

  states = [
    { 
      id: 1,
      name: 'Alabama'
    },
    {
      id: 2,
      name: 'North Dakota'
    },
    {
      id: 3,
      name: 'Mississippi'
    }
  ];

  constructor() {
    this.stateCtrl = new FormControl();
    this.filteredStates = this.filterStates('');
  }

  onKeyUp(event: Event): void {
    this.filteredStates = this.filterStates(event.target.value);
  }

  filterStates(val: string): Observable<any> {
    let arr: any[];
    console.log(val)
    if (val) {
      arr = this.states.filter(s => new RegExp(`^${val}`, 'gi').test(s.name));
    } else {
      arr = this.states;
    }

    // Simulates request
    return Observable.of(arr);
  }

  displayFn(value) {
    // I want to get the full object and display the name
    return value;
  }
}

テンプレート:

<md-input-container>
  <input mdInput placeholder="State" (keyup)="onKeyUp($event)" [mdAutocomplete]="auto" [formControl]="stateCtrl">
</md-input-container>

<md-autocomplete #auto="mdAutocomplete" [displayWith]="displayFn.bind(this)">
  <md-option *ngFor="let state of filteredStates | async" [value]="state.id">
    {{ state.name }}
  </md-option>
</md-autocomplete>

基本的に、それは this question とほぼ同じです(残念ながら、両方の答えが間違っているかエラーを投げます)。

[〜#〜] plunker [〜#〜] です。

10
dev_054

オブジェクト全体をmd-optionsでバインドする場合は、stateを使用してオプションにバインドし、displayFnstate.nameを返す必要があります。このようにthisをバインドする必要はありません。

<md-autocomplete #auto="mdAutocomplete" [displayWith]="displayFn">
  <md-option *ngFor="let state of filteredStates | async" [value]="state">
    {{ state.name }}
  </md-option>
</md-autocomplete>

displayFn(state) {
  return state.name;
}

デモプランカー.


state.idのみをmd-optionsにバインドする場合は、state.nameに基づいてstate.idを見つけるためにstatesをループする必要があり、この方法でthisをバインドする必要があります。

<md-autocomplete #auto="mdAutocomplete" [displayWith]="displayFn.bind(this)">
  <md-option *ngFor="let state of filteredStates | async" [value]="state.id">
    {{ state.name }}
  </md-option>
</md-autocomplete>

displayFn(id) {
  if (!id) return '';

  let index = this.states.findIndex(state => state.id === id);
  return this.states[index].name;
}

デモプランカー.

17
Pengyy