私は角2を使って取得要求と投稿要求をしています。私のget要求はうまくいきますが、私の投稿では私のFirebug Netパネルをチェックすると、要求がになっていません。角2のHTTP投稿要求が呼び出されていません
コードのメソッドは次のようになります。また、コンポーネントクラスから呼び出すサブスクライブメソッドもあります。
import {Injectable} from "angular2/core";
import {Http, Response, Headers, RequestOptions, Jsonp, URLSearchParams} from "angular2/http";
import { Observable } from 'rxjs/Observable';
import 'rxjs/add/operator/map';
@Injectable()
export class MyService{
constructor (private _http: Http){}
testPost(){
var json = JSON.stringify({"userId": 111, "givenName": "CZ"});
var body = "json="+json;
var headers = new Headers({ 'Content-Type': 'application/json' });
var options = new RequestOptions({ headers: headers });
return this._http.post("http://mylocal.post.url", body, options)
.map(this.extractData)
.catch(this.handleError);
}
private extractData(res: Response) {
alert("test whether this method is reached");
let body = res.json();
return body.data || { };
}
private handleError (error: any) {
alert("test whether this method is reached");
let errMsg = (error.message) ? error.message :
error.status ? `${error.status} - ${error.statusText}` : 'Server error';
console.error(errMsg); // log to console instead
return Observable.throw(errMsg);
}
//testGet method is running well
testGet(link:string){
return this._http.get(link)
.map(res => res);
}
}
私のサブスクライブするメソッドonTestPost()は、ページ上のボタンに割り当てられています。
onTestPost(){
this.myService.testPost()
.subscribe(
data => this.getData = JSON.stringify(data),
error => alert(error),
() => console.log("Finished")
);
}
2つのヘルパーメソッドの先頭にアラート文を挿入しました。いずれのアラートにも到達していません。また、Firebugでデバッグするときに私のローカルポストURLにリクエストが送られてきたことはありません。
私のtestGetメソッドは正しく動作しますが、testPostには何が欠落しているか分かりません。
コードは大丈夫に見えるを参照してください、あなたが本当に適切に加入していなかった可能性が高いです。 – dfsq
偽のバックエンドのようなものがリクエストを受け付けていないことを確認してください。 –