原文出处:
https://blog.csdn.net/foxweimin/article/details/50018855
kendo UI的dataSource提供了批量更新数据的方法,但是新建、更新和删除都会触发不同的服务。
若某个业务表单的数据明细有些被修改,有些被删除,有些数据又是新增的,并且这些数据更新必须一次性提交做事务处理,那就必须自己提交数据进行处理了。
但是如何从datasource中提取这些变化的数据呢。
1、新增的数据:
dataSource.data()返回kendo.data.Model类型的数组,每个kendo.data.Model都有一个方法isNew(),它的返回值为1的话表示是新增数据
2、删除的数据:
dataSource有个属性_destroyed,它包含了所有的删除数据
3、更新的数据:
dataSource.data()返回kendo.data.Model类型的数组,每个kendo.data.Model都有一个属性dirty,它的返回值为1的话表示数据已经被改变
kendo UI的dataSource提供了批量更新数据的方法,但是新建、更新和删除都会触发不同的服务。
若某个业务表单的数据明细有些被修改,有些被删除,有些数据又是新增的,并且这些数据更新必须一次性提交做事务处理,那就必须自己提交数据进行处理了。
但是如何从datasource中提取这些变化的数据呢。
1、新增的数据:
dataSource.data()返回kendo.data.Model类型的数组,每个kendo.data.Model都有一个方法isNew(),它的返回值为1的话表示是新增数据
2、删除的数据:
dataSource有个属性_destroyed,它包含了所有的删除数据
3、更新的数据:
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 that = this;
var delta=new Array();
// 删除记录
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;
}
});