Edit: Read the part at the end of the question!
I get this error:
My service code:
import { Http, Response, Headers } from "@angular/http";
import { Injectable } from "@angular/core";
import 'rxjs/add/operator/map';
import 'rxjs/add/operator/catch';
import { Observable } from "rxjs";
import { Client } from "./client.model";
@Injectable()
export class ClientService {
private clients: Client[] = [];
constructor(private http: Http){}
addClient(client: Client) {
this.clients.push(client);
const body = JSON.stringify(client);
const headers = new Headers({'Content-Type': 'application/json'});
return this.http.post('http://localhost:3000/client', body, {headers: headers})
.map((response: Response) => response.json())
.catch((error: Response) => Observable.throw(error.json()));
}
getClients() {
return this.clients;
}
deleteClient(client: Client) {
}
}
And in my component I have this submit function:
onSubmit(form: NgForm) {
let email = form.value.email;
let password = form.value.password;
let firstName = form.value.firstName;
let lastName = form.value.lastName;
const client = new Client(email, password, firstName, lastName);
this.clientService.addClient(client)
.subscribe(
data => console.log(data),
error => console.error(error)
);
form.resetForm();
}
There are similar errors here and here. The answer is always to include the rxjs functions, but I do that, so I'm not quite sure, why I get this error.
Edit:
So the actual problem was not this function, but a missing "/" before my route in the main app.js file. After solving that, the issue was gone.
json is not a function" error occurs when we call the json() method on an object that is not the Response object that resolves from the promise the fetch() method returns, or call the json() method on the return value from calling an axios method.
json() The json() method of the Response interface takes a Response stream and reads it to completion. It returns a promise which resolves with the result of parsing the body text as JSON .
Don't catch and rethrow. Just handle the exception when you consume the service.
.map(response => response.json());
Or if you want to handle the exception in your service, and just return an error you can do the following
.map(response => response.json())
.catch(error => Observable.throw("Error in x service"));
You can see the documentation of Observable.throw and how it is used.
The error object you are getting is malformed. You can add some console logs to see what you are getting back. But it is causing issues.
Well, like it states. The error returned from the observable does not contain the json
method. This means that it is not of the type Response
, but it just contains the error. You should just try to print out the object in your console and see what's in there:
.catch((error: any) => console.log(error))
You will probably find it's just an xmlhttpresponse
object
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