我使用网格剑桥(Angular 2)在网格中添加/编辑/删除一行:
http://www.telerik.com/kendo-angular-ui/components/grid/editing/
在原始代码中,数据是从这样的休息服务获得的:
private fetch(action: string = "", data?: Product): Observable<Product[]> {
return this.jsonp
.get(`http://demos.telerik.com/kendo-ui/service/Products/${action}? callback=JSONP_CALLBACK${this.serializeModels(data)}`)
.map(response => response.json());
}
但是,我想使用一个数组来添加/编辑/删除内存中的行 . 接下来,我想点击按钮提交并将数据(包括我的所有更改)发送到服务器 .
我的解决方案是这样的:
https://gist.github.com/joedayz/9e318a47d06a7a8c2170017eb133a87e
Overview :
我宣布一个数组:
private view:Array = [{ProductID:1,ProductName:“pelotas”,Discontinued:undefined,UnitsInStock:80}];
并覆盖fetch方法,如下所示:
private fetch(action: string = "", data?: Product): Observable<Product[]> {
/*return this.jsonp
.get(`http://demos.telerik.com/kendo-ui/service/Products/${action}?callback=JSONP_CALLBACK${this.serializeModels(data)}`)
.map(response => response.json());*/
debugger;
if(action=="create"){
var product : Product = new Product(-1, data.ProductName, data.Discontinued, data.UnitsInStock);
this.view.push(product);
}else if(action=="update"){
var indice = this.view.indexOf(data);
if(indice>=0)
this.view[indice] = (JSON.parse(JSON.stringify(data)));
}else if(action=="destroy"){
var indice = this.view.indexOf(data);
if(indice>=0)
this.view.splice(indice, 1);
}
return Observable.of(this.view);
}
我的问题是:存在某种方式将创建/更新/删除我的数组中的项目简单或反应形式传递给我的网格?
1 回答
在使用内存数组时,您不需要使用Observable . Grid组件已经绑定到数组,因此只需要操作数据 . 例如: