The docs state when using HttpClient
...
this.http.get('/api/items').subscribe(data => {
// Read the result field from the JSON response.
this.results = data['results'];
});
In the above example, the data['results']
field access stands out because you use bracket notation to access the results field. If you tried to write data.results
, TypeScript would correctly complain that the Object coming back from HTTP does not have a results
property. That's because while HttpClient
parsed the JSON response into an Object, it doesn't know what shape that object is.
So your options are to either type your response (which both docs and I would suggest), or then use the bracket notation.
Typing the response would be to create an interface/class, which you tell that it is what you expect from the request:
export interface MyResponse {
results: // your type here
}
this.http.get<MyResponse>('/api/items').subscribe(data => {
this.results = data.results;
});