Os métodos HttpClient permitem definir os parâmetros nas opções.
Você pode configurá-lo importando o HttpClientModule do pacote @ angular / common / http.
import {HttpClientModule} from '@angular/common/http';
@NgModule({
imports: [ BrowserModule, HttpClientModule ],
declarations: [ App ],
bootstrap: [ App ]
})
export class AppModule {}
Depois disso, você pode injetar o HttpClient e usá-lo para fazer a solicitação.
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);
}
}
Para versões angulares anteriores à versão 4, você pode fazer o mesmo usando o serviço Http .
O método Http.get usa um objeto que implementa RequestOptionsArgs como um segundo parâmetro.
O campo de pesquisa desse objeto pode ser usado para definir uma string ou um objeto URLSearchParams .
Um exemplo:
// 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()
);
A documentação para a classe Http tem mais detalhes. Pode ser encontrado aqui e um exemplo de trabalho aqui .