I metodi HttpClient ti consentono di impostare i parametri nelle sue opzioni.
È possibile configurarlo importando HttpClientModule dal pacchetto @ angular / common / http.
import {HttpClientModule} from '@angular/common/http';
@NgModule({
imports: [ BrowserModule, HttpClientModule ],
declarations: [ App ],
bootstrap: [ App ]
})
export class AppModule {}
Successivamente è possibile iniettare HttpClient e utilizzarlo per eseguire la richiesta.
import {HttpClient} from '@angular/common/http'
@Component({
selector: 'my-app',
template: `
<div>
<h2>Hello {{name}}</h2>
</div>
`,
})
export class App {
name:string;
constructor(private httpClient: HttpClient) {
this.httpClient.get('/url', {
params: {
appid: 'id1234',
cnt: '5'
},
observe: 'response'
})
.toPromise()
.then(response => {
console.log(response);
})
.catch(console.log);
}
}
Per le versioni angolari precedenti alla versione 4 puoi fare lo stesso usando il servizio Http .
Il metodo Http.get accetta un oggetto che implementa RequestOptionsArgs come secondo parametro.
Il campo di ricerca di quell'oggetto può essere utilizzato per impostare una stringa o un oggetto URLSearchParams .
Un esempio:
// Parameters obj-
let params: URLSearchParams = new URLSearchParams();
params.set('appid', StaticSettings.API_KEY);
params.set('cnt', days.toString());
//Http request-
return this.http.get(StaticSettings.BASE_URL, {
search: params
}).subscribe(
(response) => this.onGetForecastResult(response.json()),
(error) => this.onGetForecastError(error.json()),
() => this.onGetForecastComplete()
);
La documentazione per la classe Http ha maggiori dettagli. Può essere trovato qui e un esempio funzionante qui .