Я новичок в Angular2 и пытаюсь просмотреть объект JSON, который я получаю обратно из GET-запроса, но не могу разобраться с этим.
Мой JSON объект:.
{
Results: [{
Time: "2017-02-11T08:15:01.000+00:00",
Id: "data-mopdsjkajskda",
AuthorId: "58fSDNJD"
}, {
Time: "2017-03-11T06:23:34.000+00:00",
Id: "data-2371212hjb1",
AuthorId: "43555HHHJ"
}, {
Time: "2017-04-11T07:05:11.000+00:00",
Id: "data-kjskdha22112",
AuthorId: "XDSJKJSDH"
}]
}
Часть моего сценария Angular:
interface res {
Time: string;
Id: string;
AuthorId: string;
}
export class AppComponent {
results: res;
constructor(private _httpservice: HTTPService) {}
this._httpservice.getQuery().subscribe(
data => {
this.results = data.Results
},
error => console.log(error),
() => console.log('Done')
);
}
Я получаю данные обратно - и это замечательно. Однако я хочу поместить идентификаторы в массив. В Javascript я бы сделал следующее:
var ids = [];
for (i = 0; i < data.Results.length; i++) {
ids.push(data.Results[i].Id)
}
Массив после выталкивания:
ids = ['data-mopdsjkajskda', 'data-2371212hjb1', 'data-kjskdha22112'];
Я пытаюсь найти способ достичь тех же результатов с помощью Angular2. Любая помощь будет очень признательна!
Если ваш объект json из GET-запроса выглядит как тот, который вы опубликовали выше, просто сделайте:
let list: string[] = [];
json.Results.forEach(element => {
list.push(element.Id);
});
Или я что-то упустил, что мешает вам сделать это таким образом?
В ECMAScript 6 появился оператор let
. Вы можете использовать его в операторе for
.
var ids:string = [];
for(let result of this.results){
ids.push(result.Id);
}