は、コンソールに出力「ガットデータ」をnodejs。しかし、Angular2はサーバーにデータを送信しないようです。 Screenshot PostMan角度2サービスHTTP POSTをdoesntの仕事
何が問題なのですか?
NodeJS server.js:
api.post('/updateLocation', function(req, res){
//res.send(req.body);
console.log('Got data');
});
イオン2 home.ts:
import {Component} from '@angular/core';
import {NavController} from 'ionic-angular';
import {Service} from '../../service';
@Component({
templateUrl: 'build/pages/home/home.html',
providers: [Service]
})
export class HomePage {
constructor(private navCtrl: NavController, service: Service) {
setInterval(()=> {
service.sendLocation({ x: '46.303344', y: '28.655268' });
}, 1000);
}
}
service.ts:によって解決
import {Injectable} from '@angular/core';
import {Http, Headers} from '@angular/http';
@Injectable()
export class Service {
http : any;
url : string = 'http://localhost:3000/api/updateLocation';
constructor(http: Http){
this.http = http;
}
sendLocation(location){
let body = JSON.stringify(location);
let headers = new Headers();
headers.append('Content-Type', 'application/json');
return this.http.post(this.url, body, { headers });
}
}
は、このデータ変数では、サーバからのJSON-ED応答のですか?したがって、ノードがres.json({a:b})としてrequiestに応答する場合、data = {a:b}?しかし、あなたが議論なしで購読しているのを見ることができるので、私の答えはどちらも正しいと思います。 –
はい、 'data'には応答が含まれています。実際には、@ angular/httpモジュールのResponseオブジェクトです。 'data'変数はもちろんあなたが好きなものであれば何でも構いません。 – Delosdos