jqgrid多行添加保存,jqgrid多行删除



//保存添加行的id编号
var newrowids = new Array() ;
//给grid添加行
function addRow($jqgrid)
{
jqgrid 多行添加及删除解决思路
//获得jqgrid所有编号
var ids = $jqgrid.jqGrid('getDataIDs');
//获得第一行的role
var $firstTrRole = $("#plsfList").find("tr").eq(1).attr("role");
//如果jqgrid中没有数据 定义最大行号为100 ,否则取当前最大行号
var rowid = $firstTrRole == "row" ? Math.max.apply(Math,ids):100;
//获得新添加行的行号(数据编号)
var newrowid = parseInt(rowid)+1;
newrowids[newrowids.length]= newrowid ;
//定义row
var dataRow = {
id: "",
valid:"",
zoneID:'',
factorPG:'',
factorQG:'',
factorPL:'',
factorQL:'',
caseID:''
};
//将新添加的行插入到第一列
$jqgrid.jqGrid("addRowData", newrowid, dataRow, "first");
}


/*--------------数据保存----- -----------*/
function doSave($jqgrid){
var result = getParamArray($jqgrid);
var checkResult = result[0];
var paramArray = result[1];
if(checkResult){
//异步保存比例因子
saveDataBatch(paramArray,newrowids);
}

}


/*--------------获取参数数组----------------
* return : array (element1:验证结果 ; element2:参数数组)
*/
function getParamArray($jqgrid){
//定义参数数组
var paramArray = new Array();
var $check_val ;
var $zoneval ;
var $pasfval ;
var $pisfval ;
var $lasfval ;
var $lisfval ;
var rowidslength = newrowids.length;
var checkResult = true;
for(var i = rowidslength-1 ; i>= 0 ; i--){
var $params = $jqgrid.find("input[id^="+newrowids[i]+"]");
$check_val = $params.eq(0).is(':checked') ? 1:0;
$zoneval = $params.eq(1).val() ;
$pasfval = $params.eq(2).val() ;
$pisfval = $params.eq(3).val() ;
$lasfval = $params.eq(4).val() ;
$lisfval = $params.eq(5).val() ;

//校验参数 :当单数据成功,添加数组;否则跳出循环
if(checkParam($params,$zoneval,$pasfval,$pisfval,$lasfval,$lisfval)){
//定义比例因子对象
var param = new Object();
param.valid = $check_val ;
param.zoneID = $zoneval ;
param.factorPG = $pasfval ;
param.factorQG = $pisfval ;
param.factorPL = $lasfval ;
param.factorQL = $lisfval ;
param.caseID = $("#caseID").val() ;
paramArray[paramArray.length] = param ;
}else{
checkResult = false ;
break;
}
}
return [checkResult ,paramArray];
}


/*--------------批量保存数据------------------
* param: paramArray 数据组 ;
* newrowids 添加行的id编号
*/
function saveDataBatch(paramArray,newrowids){
var json = JSON.stringify(paramArray);
var url = '<%=basePath%>'+"/saveBatch" ;
$.ajax({url:url,type:"post",timeout:5000,data:{json:json},
success:function(data){
alert(data);
//重新加载页面
reloadGrid();
//将添加行的编号数组制空
newrowids.length = 0 ;

});
}

/*--------------批量删除----- -----------*/
function deleteBatch($jqgrid){
var ids=$jqgrid.jqGrid("getGridParam", "selarrrow");
//如果当前页面没有正在编辑的数据 就去数据库删除
if (!isRowNeedSave($jqgrid)){
crudDeleteSelected(ids, "<c:url value='delete' />");
}
//仅是在页面删除
else{
if(ids==null || ids.length==0)
{
alert("请选择要删除的记录");
return;
}
if(confirm("确定删除选中的记录吗?"))
{
var idsL = ids.length ;
for(var i =0 ; i<idsL ; i++){
$jqgrid.find("tr[id="+ids[i]+"]").remove();
//删除当前删除行的编号
newrowids.remove(ids[i]);
}

}
}
}


/*-------判断当前grid中是否存在需要编辑的行 开始-----------*/
function isRowNeedSave($jqgrid){
return getEditRowCount($jqgrid) > 0 ? true : false ;
}


  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值