angular 8 - Ошибка при попытке сравнить '[объект Object]'. Разрешены только массивы и итерации.

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

TS -

  searchKeywords: string;
  CoffeeItemList: any = [];

  // tslint:disable-next-line:max-line-length
  constructor(private getDataListingService: DataListingService){}
  ngOnInit() {
    this.getGlobalSearchList('');
  }

  getGlobalSearchList(type: string) {
    this.CoffeeItemList = [];
    this.getDataListingService.getAllDataLists().subscribe(value => {
      let data = [];
      data = value.data;
      console.log(data);
      for (let i = 0; i < data.length - 1; i++) {
        if (data[i].type === type) {
            this.CoffeeItemList.push(data[i]);
        }
    }
    });
  }
  getSmartSearchValues(search: string) {
    if (search === '' ) {
      this.getGlobalSearchList('');
      return false;
    }
    this.getDataListingService.searchList(search).subscribe((data: any) => {
      this.CoffeeItemList = data;
    });

HTML

    <div class="container">
  <div class="mt-4">
    <input  class="form-control" type="text" [(ngModel)]="searchKeywords" (keyup)="getSmartSearchValues(searchKeywords)" placeholder="Search here"/>
  </div>
  <br>
  <!-- Nav tabs -->
  <ul class="nav nav-tabs" role="tablist">
    <li class="nav-item">
      <a class="nav-link active" data-toggle="tab" href="#list" (click)="getGlobalSearchList('DancingGoatMvc-Coffee')">Coffee</a>
    </li>
    <li class="nav-item">
      <a class="nav-link" data-toggle="tab" href="#list" (click)="getGlobalSearchList('DancingGoatMvc-Brewer')">Brewer</a>
    </li>
  </ul>
  <!-- Tab panes -->
  <div class="tab-content">
    <div id="list" class="tab-pane container active in"><br>
      <div class="row">

      <div class="card col-3" *ngFor="let items of CoffeeItemList">
        <div class="card-body">
          <h5 class="card-title">{{items?.title }}</h5>
          <img src="http://infogainpune.com{{items.image |slice:1}}" class="w-100"/>
          <p class="card-text">{{items?.content}}</p>
          <h4 class="card-text">${{items?.price}}</h4>
          <h4 class="card-text">{{items?.type}}</h4>
        </div>
      </div>
    </div>
    </div>
  </div>
</div>

Ответ данных

введите описание изображения здесь


person Pratiksha Kale    schedule 12.02.2020    source источник
comment
может быть, вы пытаетесь выполнить итерацию по объекту   -  person Sajeetharan    schedule 12.02.2020
comment
Какой тип ответа у data?   -  person Mridul    schedule 12.02.2020
comment
medium.com/@nacimidjakirene/, я думаю, это будет помощь   -  person shashi kumar    schedule 12.02.2020
comment
@tony ngo - не могли бы вы поделиться обновленным кодом, который вы опубликовали   -  person Pratiksha Kale    schedule 12.02.2020


Ответы (1)


Попробуйте изменить свой код и посмотрите, работает ли он для вас

this.getDataListingService.getAllDataLists().subscribe(value => {
      this.CoffeeItemList = value.data;
});

Сообщите мне, если проблема не исчезнет.

person Tony Ngo    schedule 12.02.2020