0
jqgrid hideColメソッドはフッターに反映されていないようです。 つまり、hideColメソッドを使用してBを非表示にすると、列A BとCが表示され、フッターBが非表示になっていないフッターが不正確になります。 ここに何かが見つからないのですか、それともサポートされていませんか?フッターに関してhideColの言及が見つかりませんでした。jqgrid hideColフッタ列を非表示にしない
動作しないサンプルコードを提供する サンプルJqGrid Samplesにフッタを追加して、名前欄に非表示を追加しました。ここでフッターは対応する列を隠さなかった。
var mydata = [
{ id: "1", invdate: "2010-05-24", name: "test", note: "note", tax: "10.00", total: "2111.00" },
{ id: "2", invdate: "2010-05-25", name: "test1", note: "note2", tax: "20.00", total: "320.00" },
{ id: "3", invdate: "2007-09-01", name: "test1", note: "note3", tax: "30.00", total: "430.00" },
{ id: "4", invdate: "2007-10-04", name: "test", note: "note", tax: "10.00", total: "210.00" },
{ id: "5", invdate: "2007-10-05", name: "test2", note: "note2", tax: "20.00", total: "320.00" },
{ id: "6", invdate: "2007-09-06", name: "test3", note: "note3", tax: "30.00", total: "430.00" },
{ id: "7", invdate: "2007-10-04", name: "test", note: "note", tax: "10.00", total: "210.00" },
{ id: "8", invdate: "2007-10-03", name: "test2", note: "note2", amount: "300.00", tax: "21.00", total: "320.00" },
{ id: "9", invdate: "2007-09-01", name: "test3", note: "note3", amount: "400.00", tax: "30.00", total: "430.00" },
{ id: "11", invdate: "2007-10-01", name: "test", note: "note", amount: "200.00", tax: "10.00", total: "210.00" },
{ id: "12", invdate: "2007-10-02", name: "test2", note: "note2", amount: "300.00", tax: "20.00", total: "320.00" },
{ id: "13", invdate: "2007-09-01", name: "test3", note: "note3", amount: "400.00", tax: "30.00", total: "430.00" },
{ id: "14", invdate: "2007-10-04", name: "test", note: "note", amount: "200.00", tax: "10.00", total: "210.00" },
{ id: "15", invdate: "2007-10-05", name: "test2", note: "note2", amount: "300.00", tax: "20.00", total: "320.00" },
{ id: "16", invdate: "2007-09-06", name: "test3", note: "note3", amount: "400.00", tax: "30.00", total: "430.00" },
{ id: "17", invdate: "2007-10-04", name: "test", note: "note", amount: "200.00", tax: "10.00", total: "210.00" },
{ id: "18", invdate: "2007-10-03", name: "test2", note: "note2", amount: "300.00", tax: "20.00", total: "320.00" },
{ id: "19", invdate: "2007-09-01", name: "test3", note: "note3", amount: "400.00", tax: "30.00", total: "430.00" },
{ id: "21", invdate: "2007-10-01", name: "test", note: "note", amount: "200.00", tax: "10.00", total: "210.00" },
{ id: "22", invdate: "2007-10-02", name: "test2", note: "note2", amount: "300.00", tax: "20.00", total: "320.00" },
{ id: "23", invdate: "2007-09-01", name: "test3", note: "note3", amount: "400.00", tax: "30.00", total: "430.00" },
{ id: "24", invdate: "2007-10-04", name: "test", note: "note", amount: "200.00", tax: "10.00", total: "210.00" },
{ id: "25", invdate: "2007-10-05", name: "test2", note: "note2", amount: "300.00", tax: "20.00", total: "320.00" },
{ id: "26", invdate: "2007-09-06", name: "test3", note: "note3", amount: "400.00", tax: "30.00", total: "430.00" },
{ id: "27", invdate: "2007-10-04", name: "test", note: "note", amount: "200.00", tax: "10.00", total: "210.00" },
{ id: "28", invdate: "2007-10-03", name: "test2", note: "note2", amount: "300.00", tax: "20.00", total: "320.00" },
{ id: "29", invdate: "2007-09-01", name: "test3", note: "note3", amount: "400.00", tax: "30.00", total: "430.00" }
];
function drawGrid() {
jQuery("#list482").jqGrid({
onSortCol: function (index, columnIndex, sortOrder) {
alert(index + ' ' + columnIndex + ' ' + sortOrder);
return 'stop';
},
data: mydata,
datatype: "local",
height: 'auto',
rowNum: 30,
sortable: true,
rowList: [10, 20, 30],
colNames: ['Inv No', 'Date', 'Client', 'Amount', 'Tax', 'Total', 'Notes'],
colModel: [
{ name: 'id', index: 'id', width: 60, sorttype: "int" },
{ name: 'invdate', index: 'invdate', width: 90, sorttype: "date", formatter: "date" },
{ name: 'name', width: 100, editable: true },
{ name: 'amount', index: 'amount', width: 80, align: "right", sorttype: "float", formatter: "number", editable: true },
{ name: 'tax', index: 'tax', width: 80, align: "right", sorttype: "float", editable: true },
{ name: 'total', index: 'total', width: 80, align: "right", sorttype: "float" },
{ name: 'note', index: 'note', width: 150, sortable: false }
],
viewrecords: true,
grouping: false,
groupingView: {
groupField: ['name'],
groupColumnShow: [true],
groupText: ['<b>{0} - {1} Item(s)</b>']
},
footerrow: true,
caption: "Hide Grouping Column",
onCellSelect: function() { alert('focus'); }
});
var grid = jQuery("#list482");
var col = 0;
for (var row = 0; row < mydata.length; row++) {
grid.addRowData(row + 1, { id: '' });
grid.setCell(row + 1, col, mydata[row].id);
grid.setCell(row + 1, col + 1, mydata[row].invdate);
grid.setCell(row + 1, col + 2, mydata[row].name);
grid.setCell(row + 1, col + 3, mydata[row].amount);
grid.setCell(row + 1, col + 4, mydata[row].tax);
grid.setCell(row + 1, col + 5, mydata[row].total);
grid.setCell(row + 1, col + 6, mydata[row].note);
}
grid.footerData('set', { amount: 2000, tax: 5000, total: 90000 });
grid.hideCol(['name']);
grid.trigger("reloadGrid");
}
$(document).ready(function() {
drawGrid();
});
'hideCol'は、フッター行の対応する列も非表示にする必要があります([the line](https://github.com/tonytomov/jqGrid/blob/v4.3.1/js/grid.base.js#L2973を参照)。 )のコード)。それが動作していない例がある場合は、対応するデモを投稿する必要があります。 – Oleg
これを指摘していただきありがとうございます。私は物事を乱している私のコードを調べてみるつもりです。 – Sarath
あなたはようこそ!いずれにしても、バグを見つけたと思われる場合は、問題を再現するために使用できる完全なコードを投稿する必要があります。 – Oleg