gpt4 book ai didi

angular - 将 Observable 映射到对象数组

转载 作者:搜寻专家 更新时间:2023-10-30 22:04:43 26 4
gpt4 key购买 nike

我有 rest api,它返回带有数据的 json 数组。在客户端,我使用此代码根据请求创建对象。

public getNews(): Observable<News[]> {

return this.http.get(this.baseUrl + '/news')
.pipe(
catchError(this.handleError('getNews', []))
)
.map(res => {
let response: any = res;
return response.map((item) => new News(item));
});
}

订阅:

this.restProvider.getNews().subscribe((news: News[]) => {
this.news = news;
});

但是当响应不是数组而是单个元素时,我该如何解决问题呢?或者响应是错误的,例如来自 API 的意外数据?

目前在这些情况下,我的应用程序会抛出此错误:

response.map is not a function

最佳答案

下面的代码可以帮助您处理错误:

this.restProvider.getNews().subscribe((news: News[]) => {
this.news = news;
}, (err) => {
console.log(err);
});

只需要在订阅函数中添加error参数即可。

现在开始您的第一个问题:如果响应是单个对象怎么办?-> 函数的签名总是强制它返回一个数组。该错误将在订阅端生成。一个简单的解决方案是更改响应的数据类型。

this.restProvider.getNews().subscribe((news:any) => {
this.news = news;
});

关于angular - 将 Observable 映射到对象数组,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/49792196/

26 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com