angular 8 - Грешка при опит за разлика „[object 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="/bg#list" (click)="getGlobalSearchList('DancingGoatMvc-Coffee')">Coffee</a>
    </li>
    <li class="nav-item">
      <a class="nav-link" data-toggle="tab" href="/bg#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