jgrid 多选 快捷键,JQGrid-多选

Multiselect in JQGrid only allows either multiple selection or single selections and the shift functionality isn't what I'd expect the shift select to do. I also don't like that we need comboboxes with multiselect.

What other solution could I use for multiselect?

解决方案

[Oct 2011] Updated to use 4.0 API, corrected shift-selection bugs, simplified selection loop. Tested in 4.2.0.

If like me, you needed a proper multiselect in the jqgrid - where ctrl selects a single row at a time, select selects multiple rows and neither clear the selection and selects 1 row - You've found it.

First things first: set multiselect: true in the grid definition (I didn't set any other multiselect options)

Next: In gridComplete: function () {} set grid.jqGrid('hideCol', 'cb'); - this hides the checkboxes if you don't want them.

Finally: The main part

beforeSelectRow: function (rowid, e) {

if (!e.ctrlKey && !e.shiftKey) {

$("#grid").jqGrid('resetSelection');

}

else if (e.shiftKey) {

var initialRowSelect = $("#grid").jqGrid('getGridParam', 'selrow');

$("#grid").jqGrid('resetSelection');

var CurrentSelectIndex = $("#grid").jqGrid('getInd', rowid);

var InitialSelectIndex = $("#grid").jqGrid('getInd', initialRowSelect);

var startID = "";

var endID = "";

if (CurrentSelectIndex > InitialSelectIndex) {

startID = initialRowSelect;

endID = rowid;

}

else {

startID = rowid;

endID = initialRowSelect;

}

var shouldSelectRow = false;

$.each($("#grid").getDataIDs(), function(_, id){

if ((shouldSelectRow = id == startID || shouldSelectRow)){

$("#grid").jqGrid('setSelection', id, false);

}

return id != endID;

});

}

return true;

}

The End - Hope that helps

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

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值