使用 Angular2 中的接口将对象推入新数组
Push object into new array with interfaces in Angular2
我正在从 Angular2 中的服务中检索对象列表。
单击时,我想将我的 ngFor 中的对象放到一个新数组(具有相同的界面)上。
我能够很好地显示包含项目的列表。我也可以在控制台中显示我选择的项目,但我无法将此对象推送到具有相同界面的新数组中。
我的界面:
export interface Item {
id: string,
name: string,
icon_url: string,
exterior: string,
type: string,
tag: string,
addedClass: string,
selected: boolean
}
我的组件:
import {Component, OnInit, DoCheck} from 'angular2/core';
import {Item} from './../interfaces/interfaces.ts';
import {ItemService} from './../services/item.service.ts';
@Component({
template: `
<h2>Add item</h2>
<div class="itemlist">
<ul class="items">
<li
*ngFor="#item of items"
[class.selected]="item === selectedItem"
(click)="onSelect(item)"
>
<span class="item">
{{item.name}}
</span>
</li>
</ul>
</div>
`
})
export class AddTradeComponent implements OnInit {
public items: Item[];
public selectedItems: Item[];
constructor(private _itemService: ItemService) { }
getUserItems() {
this._itemService.getUserItems().then(userItems => this.items = userItems);
}
ngOnInit() {
this.getUserItems();
}
onSelect(item) {
console.log('items ', item);
this.selectedItems.push(item);
}
}
我遇到的错误:
Error during evaluation of "click"
TypeError: Cannot read property 'push' of undefined
记录对象工作正常,我只是无法将其推送到 this.selectedItems。
您没有初始化数组。在声明成员变量时初始化数组:
public items: Item[] = [];
public selectedItems: Item[] = [];
或者在你的构造函数中初始化它们:
constructor() {
this.items = [];
this.selectedItems = [];
}
我正在从 Angular2 中的服务中检索对象列表。
单击时,我想将我的 ngFor 中的对象放到一个新数组(具有相同的界面)上。
我能够很好地显示包含项目的列表。我也可以在控制台中显示我选择的项目,但我无法将此对象推送到具有相同界面的新数组中。
我的界面:
export interface Item {
id: string,
name: string,
icon_url: string,
exterior: string,
type: string,
tag: string,
addedClass: string,
selected: boolean
}
我的组件:
import {Component, OnInit, DoCheck} from 'angular2/core';
import {Item} from './../interfaces/interfaces.ts';
import {ItemService} from './../services/item.service.ts';
@Component({
template: `
<h2>Add item</h2>
<div class="itemlist">
<ul class="items">
<li
*ngFor="#item of items"
[class.selected]="item === selectedItem"
(click)="onSelect(item)"
>
<span class="item">
{{item.name}}
</span>
</li>
</ul>
</div>
`
})
export class AddTradeComponent implements OnInit {
public items: Item[];
public selectedItems: Item[];
constructor(private _itemService: ItemService) { }
getUserItems() {
this._itemService.getUserItems().then(userItems => this.items = userItems);
}
ngOnInit() {
this.getUserItems();
}
onSelect(item) {
console.log('items ', item);
this.selectedItems.push(item);
}
}
我遇到的错误:
Error during evaluation of "click"
TypeError: Cannot read property 'push' of undefined
记录对象工作正常,我只是无法将其推送到 this.selectedItems。
您没有初始化数组。在声明成员变量时初始化数组:
public items: Item[] = [];
public selectedItems: Item[] = [];
或者在你的构造函数中初始化它们:
constructor() {
this.items = [];
this.selectedItems = [];
}