我在項目中使用jqGrid時,采用異步加載服務器數據,例如點擊翻頁、搜索時都重新加載數據。這樣就會產生一個問題。
問題描述:
當對列表批量刪除時,可以選擇多個記錄信息,選擇當前頁的第一條,如圖:
 
點擊下一頁再選擇一些記錄,點擊刪除時,則無法刪除前面頁所選擇的記錄。
解決辦法:jqGrid貌似沒有解決這個問題的方法,所以只能自己寫代碼保存所選擇的記錄。需要借助jqGrid的兩個事件方法:
/**multiselect為ture,且點擊頭部的checkbox時才會觸發此事件。aRowids:所有選中行的id集合,為一個數組。status:boolean變量說明checkbox的選擇狀態,true選中false不選中。無論checkbox是否選擇,aRowids始終有 值**/onSelectAll(aRowids,status)/**當選擇行時觸發此事件。rowid:當前行id;status:選擇狀態,當multiselect 為true時此參數才可用**/onSelectRow(aRowids,status)
大體代碼
//保存選擇記錄的數組var selectIds = new Array();jQuery("#gridid").jqGrid({  onSelectAll:function(aRowids,status){  if(status==true){    $.each(aRowids,function(i,item){     saveIdToArray(item);   })  }else{   $.each(aRowids,function(i,item){    deleteIdFromArray(item);  })  }  },  onSelectRow:function(aRowids,status){  if(status==true){ //選擇   saveIdToArray(aRowids);  }else{ //取消選擇   deleteIdFromArray(aRowids);  } } })//保存到數組function saveIdToArray(item){ var exit = false; for(var i = 0;i < selectIds.length;i++){  if(item == selectIds[i]){   exit = true;   break;  } }  selectAssets.push(item); }  }//從數組中刪除function deleteIdFromArray(item){ if(selectIds.length > 0){  for(var i = 0;i < selectIds.length;i++){   if(item == selectIds[i]){    selectIds.splice(i,1);    break;   }  } }}操作時,只對數組進行操作就可以了。
以上所述是小編給大家介紹的jqGrid翻頁時數據選中丟失問題的解決辦法,希望對大家有所幫助,如果大家有任何疑問請給我留言,小編會及時回復大家的。在此也非常感謝大家對武林網網站的支持!
新聞熱點
疑難解答