所以我有一个服务可以做一些http API调用......
我在网上找到的所有例子都假设返回的JSON是有效的......
我想要做的是在http
中触发与catch块相同的调用所以
getData(id: string): Observable<someEntity>{
return this.http.get(someUrl)
.map(this.handleResponse.bind(this))
.catch(this.handleError);
}
private handleResponse(res: Response){
if(res.status === 200){
let body = res.text();
if(!this.appService.IsJsonString(body)){
return this.handleError(new Error('The response is not valid JSON '));
}else{
return res.json() || {};
}
}
}
private handleError (error: any) {
this.appService.errorAdd(error.status, error.statusText, 'Error loading Index data', ErrorTypes.Data);
let errMsg = (error.message) ? error.message : error.status ? `${error.status} - ${error.statusText}` : 'Server error';
return Observable.throw(errMsg);
}
当我在我的组件中时:
this.myService.getData(someID)
.subscribe(
data => {...},
error => {
// LOGIC HERE
}
);
我希望这两个错误都由// LOGIC HERE(错误块)处理....而不是成功块中的一个错误而另一个错误
我做错了什么?
答案 0 :(得分:2)
按照以下方式更改handleResponse
即可满足您的要求。
private handleResponse(res: Response){
if(res.status === 200){
let body = res.text();
if(!this.appService.IsJsonString(body)){
// Throw, instead of return
throw 'The response is not valid JSON';
}else{
return res.json() || {};
}
}
}
您还可以摆脱private handleError
getData(id: string): Observable<someEntity>{
return this.http.get(someUrl)
.map(this.handleResponse.bind(this));
// Don't catch here
// Let the subscription error block to handle error throw
// .catch(this.handleError);
}
如果要隐藏组件中的RxJs对象
更改getData()调用的方式
getData(
id: string,
callback: (result: any) => void,
errorHandler) {
this.http.get(someUrl)
.map(this.handleResponse.bind(this))
.subscribe(r => callback(r), e=>errorHandler);
}
在组件
中this.myService.getData(
someID,
data => {...},
error => {
// LOGIC HERE
}
);