欢迎光临
我们一直在努力

Enable jqgrid to do/cancel selecting only selectable items

I had this requirement these days: We have a table with many rows among which some are selectable and some are not selectable, and there is also a selecting-all button which should support do/cancel selecting all selectable rows. But after glancing over the old project, I found no similar ready-made code, so I search for this by Baidu, and found solution like below (modified and beautified):

var $jqGrid = $('#grid-table');
options.multiselect = true;
// 点击全选时触发事件
options.onSelectAll = function (rowid, status) {
  // 获取jqgrid中所有数据行的id
  var rowIds = $jqGrid.jqGrid('getDataIDs');
  for (var k = 0; k < rowIds.length; k++) {
    // 获取指定id所在行的所有数据
    var curRowData = $jqGrid.jqGrid('getRowData', rowIds[k]);
    if (如果curRowData中的数据表明该行不允许进行选中的话) {
      // 设置改行不能被选中
      $jqGrid.jqGrid('setSelection', rowIds[k], false);
    }
  }
}

// 选择某行时触发事件
options.onSelectRow = function (id) {
  var curRowData = $jqGrid.jqGrid('getRowData', id);
  if (如果curRowData中的数据表明该行不允许进行选中的话) {
    // 设置改行不能被选中
    $jqGrid.jqGrid('setSelection', id, false);
  }
}

The above code seems to work well at first attempt. But you will find that you can not undo the selecting-all operation. I cannot use google for several months, therefore I use bing to search for other solutions, and thank goodness, here are the solution:

options.multiselect = true;
options.rowattr = function (item) {
    if (getString(item.status) !== '1') {
        return {'class': 'ui-state-disabled ui-jqgrid-disablePointerEvents'};
    }
};
options.beforeSelectRow = function (rowid, e) {
    return !$(e.target).closest('tr.jqgrow').hasClass('ui-state-disabled');
};

Haha! I really think the api document for jqgrid plugin is too complicated that it scares me to earnestly read it.

赞(0) 打赏(金额可任意指定)
未经允许不得转载:峰间的云 » Enable jqgrid to do/cancel selecting only selectable items
分享到: 更多 (0)

评论 抢沙发

  • 昵称 (必填)
  • 邮箱 (必填)
  • 网址

上海宝山顾村棉被加工店 专业加工新旧棉被

查看详情了解一下

觉得文章有用就打赏一下文章作者

支付宝扫一扫打赏

微信扫一扫打赏