Ошибка типа: невозможно прочитать свойство 'items' из неопределенного - PullRequest
1 голос
/ 02 мая 2020

Я пытаюсь разработать веб-страницу, используя Angular 8, где я получаю ответ от REST API в формате JSON на передачу идентификатора запроса, и я хочу связать эти данные в таблицу, которую я создал в HTML. Я получаю следующую ошибку:

TypeError: Невозможно прочитать свойство 'items' из неопределенного.

Ниже my items.component.html

<html lang="en">
<head>
  <title>Bootstrap Example</title>
  <meta charset="utf-8">
  <meta name="viewport" content="width=device-width, initial-scale=1">
  <link rel="stylesheet" href="https://maxcdn.bootstrapcdn.com/bootstrap/4.4.1/css/bootstrap.min.css">
  <script src="https://ajax.googleapis.com/ajax/libs/jquery/3.4.1/jquery.min.js"></script>
  <script src="https://cdnjs.cloudflare.com/ajax/libs/popper.js/1.16.0/umd/popper.min.js"></script>
  <script src="https://maxcdn.bootstrapcdn.com/bootstrap/4.4.1/js/bootstrap.min.js"></script>
</head>
<body>
<input class="in" type="text" (keyup)="onKeyUp($event)">
<button class="btn" (click)="getResults()">Search Request</button>
<br>
<div class="container">           
  <table class="table">
    <thead>
      <tr>
        <th class="user_request_id">Request ID</th>
        <th class="asset_name">Asset Name</th>
        <th class="generated_path">Generated Path</th>
        <th class="match_percentage">Match Percentage</th>
      </tr>
    </thead>
    <tbody>
      <tr  *ngFor="let item of _items.items"> 
        <td>{{item.user_request_id}}</td>
        <td>{{item.asset_name}}</td>
        <td><a href="">{{item.generated_path}}</a></td>
        <td>{{item.match_percentage}}</td>
      </tr>
    </tbody>
  </table>
</div>

</body>
</html>

Ниже приведен файл items.component.ts

import { Component, OnInit } from '@angular/core';
import { HttpClient } from '@angular/common/http';
import { Injectable } from '@angular/core';
import { GetItemsService } from '../get-items.service';
import { Observable } from 'rxjs';

@Component({
  selector: 'app-items',
  templateUrl: './items.component.html',
  styleUrls: ['./items.component.css']
})
export class ItemsComponent implements OnInit {
  public RequestID : String;

   _items:any;
   id:String='';
   items:any;

  constructor(private service: GetItemsService) { }


  ngOnInit() {
  }
  onKeyUp(event:any){
    this.id=event.target.value;
   } 

  getResults(){
    this.service.getData(this.id).subscribe((data) => {
      console.log(data)
      this._items = data
        });
  }
}

Ниже приведен файл службы.

import { Injectable } from '@angular/core';
import { HttpClient } from '@angular/common/http';
import { Observable } from 'rxjs';

@Injectable({
  providedIn: 'root'
})
export class GetItemsService {
  constructor(private httpClient:HttpClient) { }

  public APIurl = 'sample.com';

  getData(iD):Observable<any>{
    return this.httpClient.get<any>(this.APIurl+iD);
  }
}

Ниже приведен файл JSON.

{
    "items": [{
        "user_request_id": 10,
        "asset_name": "XXX",
        "generated_path": "tbd",
        "match_percentage": "14.02"
    }],
    "first": {
        "$ref": "https://ords/xxdcode/xxdcoderest/xxdcodesuggestasset/10"
             }
}

Ответы [ 2 ]

0 голосов
/ 02 мая 2020
<div class="container" *ngif="_items">           
  <table class="table">
    <thead>
      <tr>
        <th class="user_request_id">Request ID</th>
        <th class="asset_name">Asset Name</th>
        <th class="generated_path">Generated Path</th>
        <th class="match_percentage">Match Percentage</th>
      </tr>
    </thead>
    <tbody *ngif="_items.items.length!=0">
      <tr  *ngFor="let item of _items.items"> 
        <td>{{item.user_request_id}}</td>
        <td>{{item.asset_name}}</td>
        <td><a href="">{{item.generated_path}}</a></td>
        <td>{{item.match_percentage}}</td>
      </tr>
    </tbody>
  </table>
</div>
0 голосов
/ 02 мая 2020

Я думаю, вам не хватает первого аргумента ошибки в вызове getData

 getResults(){
    this.service.getData(this.id).subscribe((err,data) => {
        if (err) {
             alert("Error");
              return;
        }
      this._items = data
        });
  }
Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...