具有子网格的jqGrid的全局展开/折叠按钮

时间:2013-10-28 12:39:17

标签: jqgrid

我正在使用带子网格配置的jqGRid来显示我的数据。我希望全球扩张和扩大折叠按钮以显示或隐藏所有子网格信息。 jqGrid库是否以任何方式提供此功能?

3 个答案:

答案 0 :(得分:5)

jqGrid没有“展开/折叠全部”。我修改了the demo the old answer,它演示了在网格上创建本地子网格。结果演示,您可以看到here

enter image description here

并且在“subgrids”列的列标题中有其他“+”按钮。如果单击该按钮,将展开所有子网格:

enter image description here

我在演示中使用了以下代码:

var subGridOptions = $grid.jqGrid("getGridParam", "subGridOptions"),
    plusIcon = subGridOptions.plusicon,
    minusIcon = subGridOptions.minusicon,
    expandAllTitle = "Expand all subgrids",
    collapseAllTitle = "Collapse all subgrids";
$("#jqgh_" + $grid[0].id + "_subgrid")
    .html('<a style="cursor: pointer;"><span class="ui-icon ' + plusIcon +
          '" title="' + expandAllTitle + '"></span></a>')
    .click(function () {
        var $spanIcon = $(this).find(">a>span"),
            $body = $(this).closest(".ui-jqgrid-view")
                .find(">.ui-jqgrid-bdiv>div>.ui-jqgrid-btable>tbody");
        if ($spanIcon.hasClass(plusIcon)) {
            $spanIcon.removeClass(plusIcon)
                .addClass(minusIcon)
                .attr("title", collapseAllTitle);
            $body.find(">tr.jqgrow>td.sgcollapsed")
                .click();
        } else {
            $spanIcon.removeClass(minusIcon)
                .addClass(plusIcon)
                .attr("title", expandAllTitle);
            $body.find(">tr.jqgrow>td.sgexpanded")
                .click();
        }
    });

答案 1 :(得分:0)

您可以简单地使其行为如下所示。

  1. 按一下按钮。

  2. onlick它调用函数,比如说toggleSubgrid();

    function toggleSubgrid(){
        if($('#YOURGRIDID td').hasClass('sgexpanded')){
            $('.ui-icon-minus').trigger('click');
        }
        else if($('#YOURGRIDID td').hasClass('sgcollapsed')){
            $('.ui-icon-plus').trigger('click');
        }
    }
    

答案 2 :(得分:0)

这适用于已加载的所有行。您可能需要根据需要调整选择器的范围。

function expandAll () {
  $( ".tree-plus" ).click();
};
function collapseAll () {
  $( ".tree-minus" ).click();
};