假设我有以下对象数组,让我们将其命名为itemArray;
{
"totalItems": 2,
"items": [
{
"id": 1,
"name": "foo"
},
{
"id": 2,
"name": "bar"
},
]
}
我有一个订阅,只返回id 2的更新结果.如何更新对象数组而不在整个数组中循环?
我想要的是下面的例子;
updateUser(user){
this.myservice.getUpdate(user.id)
.subscribe(newitem => {
this.updateArray(newitem);
});
}
updateArray(newitem){
this.itemArray.items[newitem.id].name = newitem.name
}
或者更好,替换整个对象;
updateArray(newitem){
this.itemArray.items[newitem.id] = newitem
}
然而,本例根据数组的索引更新array.那么我该如何根据newitem进行更新呢.身份证件
comments 中要求的模板:
<tr *ngFor="let u of itemsArray.items; let i = index">
<td>{{ u.id }}</td>
<td>{{ u.name }}</td>
<td>
<input type="checkbox" checked="u.accepted" [(ngModel)]="itemsArray.items[i].accepted" (ngModelChange)="updateUser(u)">
<label for="singleCheckbox-{{i}}"></label>
</td>
</tr>