Kendo UI的datasource批量更新的扩展方法
2015-11-24 21:28
495 查看
kendo UI的dataSource提供了批量更新数据的方法,但是新建、更新和删除都会触发不同的服务。若某个业务表单的数据明细有些被修改,有些被删除,有些数据又是新增的,并且这些数据更新必须一次性提交做事物处理,那就必须自己提交数据进行处理了,但是如何从datasource中提取这些变化的数据呢。
新增的数据:dataSource.data()返回kendo.data.Model类型的数组,每个kendo.data.Model都有一个方法isNew(),它的返回值为1的话表示是新增数据
删除的数据:dataSource有个属性_destroyed,它包含了所有的删除数据
更新的数据:dataSource.data()返回kendo.data.Model类型的数组,每个kendo.data.Model都有一个属性dirty,它的返回值为1的话表示数据已经被改变
var ExtDataSourceEx=kendo.data.DataSource.extend({
init: function(options){
var that = this;
kendo.data.DataSource.fn.init.call(that,options);
},
getDelta:function(){
var delta=new Array();
var that = this;
var datas=that._destroyed;
for(var i=0;i<datas.length;i++){
var newObj=JSON.parse(JSON.stringify(datas[i]));
newObj.__state__="delete";
delta.push(newObj);
};
datas=that.data();
for(var i=0;i<datas.length;i++){
var newObj=JSON.parse(JSON.stringify(datas[i]));
if(datas[i].isNew()){
newObj._state_="new";
delta.push(newObj);
};
if(datas[i].dirty&&!datas[i].isNew()){
newObj._state_="update";
delta.push(newObj);
};
};
return delta;
}
});
新增的数据:dataSource.data()返回kendo.data.Model类型的数组,每个kendo.data.Model都有一个方法isNew(),它的返回值为1的话表示是新增数据
删除的数据:dataSource有个属性_destroyed,它包含了所有的删除数据
更新的数据:dataSource.data()返回kendo.data.Model类型的数组,每个kendo.data.Model都有一个属性dirty,它的返回值为1的话表示数据已经被改变
var ExtDataSourceEx=kendo.data.DataSource.extend({
init: function(options){
var that = this;
kendo.data.DataSource.fn.init.call(that,options);
},
getDelta:function(){
var delta=new Array();
var that = this;
var datas=that._destroyed;
for(var i=0;i<datas.length;i++){
var newObj=JSON.parse(JSON.stringify(datas[i]));
newObj.__state__="delete";
delta.push(newObj);
};
datas=that.data();
for(var i=0;i<datas.length;i++){
var newObj=JSON.parse(JSON.stringify(datas[i]));
if(datas[i].isNew()){
newObj._state_="new";
delta.push(newObj);
};
if(datas[i].dirty&&!datas[i].isNew()){
newObj._state_="update";
delta.push(newObj);
};
};
return delta;
}
});
相关文章推荐
- 30.自定义UITableViewCell第一章
- 【IOS】UILabel 属性及方法
- 29.UITableView表视图第四章(添加高级)
- vue+webpack在“双十一”导购产品的技术实践
- UITableViewCell的选中时的颜色设置
- 【NGUI】通过射线检测被遮挡的物体
- 使用JAXP进行DOM解析( DocumentBuilderFactory、DocumentBuilder、Document)
- 28.UITableView表视图第三章(移动和编辑删除和添加)
- UI学习 第十章 KVC    KVO    通知
- UI学习 第九章 委托(代理)设计模式      单例设计模式
- UI学习 第八章 导航控制器
- UI学习 第七章 UITableView每行的cell不同的设置
- [TwistedFate]UITableViewCell自定义-01
- [APUE]再读之 unix 基础知识
- setMouseTracking(true)无法跟踪鼠标事件
- HDU 2253 Longest Common Subsequence Again
- UI学习 第六章 UITableView
- UI学习 第五章 UIScrollView     UIPageControl
- UI学习 第四章 UIImage    UIImageView    手势
- easyUI..关于datagrid实现追加一行做统计功能