我发现这个问题很有趣,因此我创建了演示,演示了其中一种可能的双行页脚实现:
主要思路是在标准页脚已存在的表格中添加第二行。为了消除与 jqGrid 代码的其他部分可能出现的问题,我将自定义行中的 footrow
类名替换为 myfootrow
。为了让第二个页脚具有与原始页脚相同的 CSS 设置,我在第二个页脚的单元格中添加了来自 ui.jqgrid.css
的 .ui-jqgrid tr.footrow td
副本,并使用相同的定义进行设置:.ui-jqgrid tr.myfootrow td
:
.ui-jqgrid tr.myfootrow td {
font-weight: bold;
overflow: hidden;
white-space:nowrap;
height: 21px;
padding: 0 2px 0 2px;
border-top-width: 1px;
border-top-color: inherit;
border-top-style: solid;
}
你将在下面找到完整的代码
footerrow: true,
loadComplete: function () {
var $this = $(this),
sum = $this.jqGrid("getCol", "amount", false, "sum"),
$footerRow = $(this.grid.sDiv).find("tr.footrow"),
localData = $this.jqGrid("getGridParam", "data"),
totalRows = localData.length,
totalSum = 0,
$newFooterRow,
i;
$newFooterRow = $(this.grid.sDiv).find("tr.myfootrow");
if ($newFooterRow.length === 0) {
$newFooterRow = $footerRow.clone();
$newFooterRow.removeClass("footrow")
.addClass("myfootrow ui-widget-content");
$newFooterRow.children("td").each(function () {
this.style.width = "";
});
$newFooterRow.insertAfter($footerRow);
}
$this.jqGrid("footerData", "set", {invdate: "Total (page):", amount: sum});
for (i = 0; i < totalRows; i++) {
totalSum += parseInt(localData[i].amount, 10);
}
$newFooterRow.find(">td[aria-describedby=" + this.id + "_invdate]")
.text("Grand Total:");
$newFooterRow.find(">td[aria-describedby=" + this.id + "_amount]")
.text($.fmatter.util.NumberFormat(totalSum, $.jgrid.formatter.number));
}
在代码中,我将额外的信息设置在页脚的invdate
和amount
列中。