结合上一篇文章,批量数据选择后,还要把选择的数据处理一下传给后台调用签收或者取消签收接口。
首先处理需要格式数据:
var newData = [];
for(var i = 0; i<oldData.length;i++){
var arr ={
"cgeneralhid" : oldData[i].cgeneralhid,
"entries" : [{
"cgeneralbid" : oldData[i].cgeneralbid,
"collector" : collector,
"receiveqty" : oldData[i].nshouldassistnum
}]};
newData.push(arr);
然后合并同表头不同表体数据(关键代码):
var newData= receivedData(newData);
function receivedData(arr){
for (var i = 0; i <arr.length-1; i++) {
for (var j = i+1; j <arr.length; j++) {
if(arr[i].cgeneralhid === arr[j].cgeneralhid){//如果cgeneralhid相等
//arr[i]和 arr[j]
arr[i].entries.push(arr[j].entries[0]);
arr.remove(j);
j--;
}
}
}
return arr;
}
利用冒泡排序的思想,如果表头相同,合并数组项,然后移除被合并项。此时j应该移到原来位置:j--。
还有就是j<=arr.length 改成 j<arr.length
最后,拼接外层数据:
var data = {"data":newData,"groupid":groupid,"userid":userid}
完成!
今天来这里25天了,请了几天假回去,第一个app流程走通啦。等回来就是做离线和优化了。25天就这段代码收获多一些,嗯嗯,接下来还是要多学习 ,还有很多很多东西要学。