json - Angular 5 - 获取对象时出错

标签 json angular object observable

我是 Angular 5 的新手,正在尝试从外部 API 显示对象。它显示数据但由于对象类型而引发错误

来自fixer.io的json数据

{
"success":true,
"timestamp":1529865488,
"base":"EUR",
"date":"2018-06-24",
"rates":{
  "USD":1.165473,
  "AUD":1.565348,
  "CAD":1.546355,
  "PLN":4.319264,
  "MXN":23.309846
}
}

货币.服务

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

@Injectable({
  providedIn: 'root'
})
export class CurrencyService {

private _url:string = "http://data.fixer.io/api/latest";
constructor(private http: HttpClient) { }

getEmployee(): Observable<CurrencyListMain>{
return this.http.get<CurrencyListMain>(this._url);
}
}

货币组件.ts:

import { Component, OnInit } from '@angular/core';
import { CurrencyService } from '../currency.service';

@Component({
selector: 'app-currency',
template: `<h2>Employee List</h2>
          <ul >
            <li>success: {{employees.success}}</li>
            <li>timestamp: {{employees.timestamp}}</li>
            <li>base: {{employees.base}}</li>
            <li>rates: </li>
            <li>USD: {{employees.rates.USD}}</li>
            <li>AUD: {{employees.rates.AUD}}</li>
            <li>CAD: {{employees.rates.CAD}}</li>
            <li>PLN: {{employees.rates.PLN}}</li>
            <li>MXN: {{employees.rates.MXN}}</li>
          </ul>`,
 styleUrls: ['./currency.component.css']
})
export class CurrencyComponent implements OnInit {

public rates = {}
public employees = {};

constructor(private _currencyService: CurrencyService) { }

ngOnInit() {
this._currencyService.getEmployee()
.subscribe(data => this.employees = data);
}
}

currencylist1.ts - 接口(interface):

import {UserRatesList} from './userRates' ;
export interface CurrencyListMain{
success:string,
timestamp:string,
base:string,
date:string,
rates: UserRatesList
}

userRates.ts 接口(interface):

export interface UserRatesList{
USD:number,
AUD:number,
CAD:number,
PLN:number,
MXN:number
}

出现以下错误:

 CurrencyComponent.html:5 ERROR TypeError: Cannot read property 'USD' of 
undefined
at Object.eval [as updateRenderer] (CurrencyComponent.html:7)
at Object.debugUpdateRenderer [as updateRenderer] (core.js:10776)
at checkAndUpdateView (core.js:10152)
at callViewAction (core.js:10388)
at execComponentViewsAction (core.js:10330)
at checkAndUpdateView (core.js:10153)
at callViewAction (core.js:10388)
at execComponentViewsAction (core.js:10330)
at checkAndUpdateView (core.js:10153)
at callWithDebugContext (core.js:11040)

如何正确获取observable中的对象类型

最佳答案

尝试在 html 中使用“employees?.rates”。

问题是您的 html 在数据返回之前呈现,并且由于汇率未定义,您无法访问美元。

那个?运算符将检查 null 或未定义并成功返回。

另外,你确定员工不是一个数组吗?你需要做 ngRepeat 吗?

关于json - Angular 5 - 获取对象时出错,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/51013991/

相关文章:

ios - 在每个 View Controller 中显示用户名 jsondata

css - 从 Angular 2 组件修改 CSS 关键帧

javascript - 如何将对象存储到数组中,然后在创建按钮元素中显示所有对象?

java - java上通过配置文件实例化对象

c# - 如何在 C# 中将 UIntPtr 对象转换为 IntPtr?

c# - 无法从 token 类型 'StartObject' 获取 XML 字符串值

c# - 在 ASP.NET C# 中将数组转换为 JSON 字符串

java - 运行时的部分 JSON 序列化(用于 RESTful 查询)

angular - 切换 Angular Material 中的主题 5

angular - 如何在 SVG 路径中使用 routerLink?