W httpclient metody pozwalają ustawić params w jego opcji.
Możesz go skonfigurować, importując HttpClientModule z pakietu @ angular / common / http.
import {HttpClientModule} from '@angular/common/http';
@NgModule({
imports: [ BrowserModule, HttpClientModule ],
declarations: [ App ],
bootstrap: [ App ]
})
export class AppModule {}
Następnie możesz wstrzyknąć HttpClient i użyć go do wykonania żądania.
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);
}
}
W przypadku wersji kątowych przed wersją 4 możesz zrobić to samo za pomocą usługi HTTP .
Metoda Http.get pobiera obiekt, który implementuje RequestOptionsArgs jako drugi parametr.
Pola wyszukiwania tego obiektu można użyć do ustawienia ciągu lub obiektu URLSearchParams .
Przykład:
// 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()
);
Dokumentacja dla klasy Http zawiera więcej szczegółów. Można go znaleźć tutaj, a działający przykład tutaj .