I have an abstract base class in Typescript that looks like this:
import {Http, Headers, Response} from 'angular2/http';
export abstract class SomeService {
constructor(private http:Http) {}
protected post(path:string, data:Object) {
let stringifiedData = JSON.stringify(data);
let headers = new Headers();
headers.append('Content-Type', 'application/json');
headers.append('Accept', 'application/json');
this.http.post(`http://api.example.com/${path}`, stringifiedData, { headers })
.map(res => res.json())
.subscribe(obj => console.log(obj));
}
}
It works perfectly. However, the Typescript compiler is complaining about .map(res => res.json())
. I keep getting this error:
ERROR in ./src/app/components/shared/something/some.abstract.service.ts
(13,29): error TS2339: Property 'json' does not exist on type '{}'.
I followed the examples in the angular 2 documentation, and it works. I'm just sick of staring at this error. Am I missing something?
To me this looks strange...
.map(res => (<Response>res).json())
I would do
.map((res: Response) => res.json())
You can get rid of this error by type-assertion to Response
:
.map((res: Response) => res.json())
http.post()
will return a Observable<Response>
on wich map
will require an Object of type Response
. I think that's a missing definition in the current TypeScript AngularJS .d.ts
.
If you love us? You can donate to us via Paypal or buy me a coffee so we can maintain and grow! Thank you!
Donate Us With