我正在使用带子网格配置的jqGRid来显示我的数据。我希望全球扩张和扩大折叠按钮以显示或隐藏所有子网格信息。 jqGrid库是否以任何方式提供此功能?
答案 0 :(得分:5)
jqGrid没有“展开/折叠全部”。我修改了the demo the old answer,它演示了在网格上创建本地子网格。结果演示,您可以看到here:
并且在“subgrids”列的列标题中有其他“+”按钮。如果单击该按钮,将展开所有子网格:
我在演示中使用了以下代码:
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)
您可以简单地使其行为如下所示。
按一下按钮。
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();
};