json - 如何让 Angular 的 HttpClient 返回一个对象而不是字符串?

标签 json angular typescript

如何让 HttpClient 将数据作为 JSON 对象返回?

Angular 文档说 HttpClient 应该将返回的 JSON 数据解析为一个对象。在我的项目中,它仅以字符串形式返回数据。

如果我使用 JSON.parse,我可以将数据转换为一个对象并以这种方式获取数据并且它可以工作。但从我在文章中看到的情况来看,这不是好的做法。此外,大多数文章/教程仅使用接口(interface)。

我已经创建了一个界面并尝试使用它,但它不起作用。我看了很多帖子和文章,但他们都说 HttpClient 应该默认返回一个对象。

这是我的服务的代码。 第一个函数获取用户的坐标,第二个函数使用坐标从 api 请求数据。

import { Injectable } from '@angular/core';
import { HttpClient } from '@angular/common/http';
import { Observable, pipe } from 'rxjs';
import { map } from 'rxjs/operators';
import { environment } from '../../../environments/environment';
import { Aqi } from './aqi';

@Injectable({
  providedIn: 'root'
})
export class AqiService {
  aqiUrlCoords = `${environment.apiUri}airvisual/geo/`;

  constructor(private http: HttpClient) {}

  getLocation(): Observable<any> {
    return Observable.create(observer => {
      if(window.navigator && window.navigator.geolocation) {
        window.navigator.geolocation.getCurrentPosition(
          (position) => {
            observer.next(position);
            observer.complete();
          },
          (error) => observer.error(error)
        );
      } else {
        observer.error('Unsupported Browser');
      }
    });
  }

  getGeoLocationAqi(lat, long): Observable<any> {
    return this.http.get<any>(this.aqiUrlCoords, { params: {
      lat: lat,
      long: long
    }});
  }

}

要使 getGeoLocationAqi() 函数正常工作,我必须使用这个...

getGeoLocationAqi(lat, long): Observable<any> {
    return this.http.get<any>(this.aqiUrlCoords, { params: {
      lat: lat,
      long: long
    }}).pipe(
      map(res => {
        return JSON.parse(res);
      })
    );
  }

这里是使用服务和数据的组件。 typeof 总是打印字符串。

import { Component, OnInit } from '@angular/core';
import { AqiService } from '../services/aqi/aqi.service';
import { Aqi } from './aqi';

export class GeoComponent implements OnInit {
  aqi: any;
  errorMessage: string;

  constructor(private aqiService: AqiService) {}

  ngOnInit() {
    this.getCurrentCoordinatesAqi();
  }

  getCurrentCoordinatesAqi() {
    this.aqiService.getLocation().subscribe(pos => {
      let lat = pos.coords.latitude.toString();
      let long = pos.coords.longitude.toString();
      this.aqiService.getGeoLocationAqi(lat, long).subscribe((res) => {
        this.aqi = res;
        console.log(res);
        console.log(typeof res);
      });
    }, (err) => {
      this.errorMessage = err;
    });
  }
}

这是我制作的界面。

export interface Aqi {
  status: string,
    data: {
        city: string,
        state: string,
        country: string,
        location: {
            type: string,
            coordinates: [
              number,
              number
            ]
        },
        current: {
            weather: {
                ts: string,
                hu: number,
                ic: string,
                pr: number,
                tp: number,
                wd: number,
                ws: number
            },
            pollution: {
                ts: string,
                aqius: number,
                mainus: string,
                aqicn: number,
                maincn: string
            }
        }
    }
}

这是使用 postman 从 api 返回的内容。

{
    "status": "success",
    "data": {
        "city": "Hanoi",
        "state": "Hanoi",
        "country": "Vietnam",
        "location": {
            "type": "Point",
            "coordinates": [
                105.81881,
                21.021938
            ]
        },
        "current": {
            "weather": {
                "ts": "2019-04-30T16:00:00.000Z",
                "hu": 100,
                "ic": "04n",
                "pr": 1010,
                "tp": 25,
                "wd": 70,
                "ws": 2.6
            },
            "pollution": {
                "ts": "2019-04-30T15:00:00.000Z",
                "aqius": 151,
                "mainus": "p2",
                "aqicn": 76,
                "maincn": "p2"
            }
        }
    }
}

我希望 typeof 打印 object,但它总是打印 string 除非我使用 JSON.parse()。当我使用接口(interface)时,我仍然得到字符串。感谢您的帮助!

最佳答案

您不需要解析响应,只要您的端点返回 JSON 对象并且内容类型为 application/json,http 客户端默认返回对象。您的端点可能正在返回一些文本内容类型。

关于json - 如何让 Angular 的 HttpClient 返回一个对象而不是字符串?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/56015175/

相关文章:

javascript - 如何查询javascript对象

python - 如何使用 urllib2 在 Python 中发送 header

angular - 如何实例化 Angular HttpClient?

reactjs - 使用 Material ui createStyles

java - 如何在java中自定义使用Gson对象创建的json

javascript - 如何在遍历 JSON 时仅附加一次表头

javascript - 如何编辑 Chart.js donut ?

javascript - 'typing' 变量(与接口(interface))和 'modelling'(对于 Typescript Angular 2 项目)中类的使用

angular - 过滤和分页不适用于 ngxpagination 模板

reactjs - firebase_compat_app__WEBPACK_IMPORTED_MODULE_0__.default.database 不是函数