В HTTPClient методы позволяют установить Params в его вариантах.
Вы можете настроить его, импортировав HttpClientModule из пакета @ angular / common / http.
import {HttpClientModule} from '@angular/common/http';
@NgModule({
imports: [ BrowserModule, HttpClientModule ],
declarations: [ App ],
bootstrap: [ App ]
})
export class AppModule {}
После этого вы можете внедрить HttpClient и использовать его для выполнения запроса.
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);
}
}
Для угловых версий до версии 4 вы можете сделать то же самое с помощью сервиса Http .
Метод Http.get принимает объект, который реализует RequestOptionsArgs в качестве второго параметра.
Поле поиска этого объекта можно использовать для установки строки или объекта URLSearchParams .
Пример:
// 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()
);
Документация по классу Http содержит более подробную информацию. Это можно найти здесь и рабочий пример здесь .