Free-jqgrid 工具栏搜索和 Header 分组
Free-jqgrid Toolbar searching and Header Grouping
我正在使用 free-jqgrid v4.15.5,但工具栏搜索和 Header 分组有问题。
这是我正在使用的示例代码和问题
$(document).ready(function () {
var myData = [
{ id: "1", invdate: "2007-10-01", name: "test", note: "note", amount: "200.00", tax: "10.00", closed: true, ship_via: "TN", total: "210.00" },
{ id: "2", invdate: "2007-10-02", name: "test2", note: "note2", amount: "300.00", tax: "20.00", closed: false, ship_via: "FE", total: "320.00" },
{ id: "3", invdate: "2007-09-01", name: "test3", note: "note3", amount: "400.00", tax: "30.00", closed: false, ship_via: "FE", total: "430.00" },
{ id: "4", invdate: "2007-10-04", name: "test4", note: "note4", amount: "200.00", tax: "10.00", closed: true, ship_via: "TN", total: "210.00" },
{ id: "5", invdate: "2007-10-31", name: "test5", note: "note5", amount: "300.00", tax: "20.00", closed: false, ship_via: "FE", total: "320.00" },
{ id: "6", invdate: "2007-09-06", name: "test6", note: "note6", amount: "400.00", tax: "30.00", closed: false, ship_via: "FE", total: "430.00" },
{ id: "7", invdate: "2007-10-04", name: "test7", note: "note7", amount: "200.00", tax: "10.00", closed: true, ship_via: "TN", total: "210.00" },
{ id: "8", invdate: "2007-10-03", name: "test8", note: "note8", amount: "300.00", tax: "20.00", closed: false, ship_via: "FE", total: "320.00" },
{ id: "9", invdate: "2007-09-01", name: "test9", note: "note9", amount: "400.00", tax: "30.00", closed: false, ship_via: "TN", total: "430.00" },
{ id: "10", invdate: "2007-09-08", name: "test10", note: "note10", amount: "500.00", tax: "30.00", closed: true, ship_via: "TN", total: "530.00" },
{ id: "11", invdate: "2007-09-08", name: "test11", note: "note11", amount: "500.00", tax: "30.00", closed: false, ship_via: "FE", total: "530.00" },
{ id: "12", invdate: "2007-09-10", name: "test12", note: "note12", amount: "500.00", tax: "30.00", closed: false, ship_via: "FE", total: "530.00" }
],
myGrid = $("#list");
myGrid.jqGrid({
datatype: 'local',
data: myData,
colNames: ['Inv No', 'Date', 'Client', 'Amount', 'Tax', 'Total', 'Closed', 'Shipped via', 'Notes'],
colModel: [
{ name: 'id', index: 'id', width: 70, align: 'center', sorttype: 'int' },
{
name: 'invdate', index: 'invdate', width: 80, align: 'center', sorttype: 'date',
formatter: 'date', formatoptions: { newformat: 'd-M-Y' }, datefmt: 'd-M-Y'
},
{ name: 'name', index: 'name', width: 70 },
{ name: 'amount', index: 'amount', width: 100, formatter: 'number', align: 'right' },
{ name: 'tax', index: 'tax', width: 70, formatter: 'number', align: 'right' },
{ name: 'total', index: 'total', width: 120, formatter: 'number', align: 'right' },
{
name: 'closed', index: 'closed', width: 110, align: 'center', formatter: 'checkbox',
edittype: 'checkbox', editoptions: { value: 'Yes:No', defaultValue: 'Yes' },
stype: 'select', searchoptions: { sopt: ['eq', 'ne'], value: ':All;true:Yes;false:No' }
},
{
name: 'ship_via', index: 'ship_via', width: 120, align: 'center', formatter: 'select',
edittype: 'select', editoptions: { value: 'FE:FedEx;TN:TNT;IN:Intim', defaultValue: 'Intime' },
stype: 'select', searchoptions: { value: ':All;FE:FedEx;TN:TNT;IN:Intim' }
},
{ name: 'note', index: 'note', width: 100, sortable: false }
],
rowNum: 10,
rowList: [5, 10, 20],
//pager: '#pager',
gridview: true,
ignoreCase: true,
rownumbers: false,
sortname: 'invdate',
viewrecords: true,
sortorder: 'desc',
//caption: 'Just simple local grid',
height: '100%'
});
myGrid.jqGrid('filterToolbar', { stringResult: true, searchOnEnter: false, defaultSearch: "cn" });
myGrid.jqGrid('setGroupHeaders', {
useColSpanStyle: true, groupHeaders:
[
{ startColumnName: 'invdate', numberOfColumns: 5, titleText: "Group column 1" },
{ startColumnName: 'closed', numberOfColumns: 3, titleText: "Group column 2" },
]
});
});
如果有 只有一个 Header 分组级别
,则网格效果很好
当我添加更多 Header 分组级别时,工具栏搜索出现问题
free-jqgrid的这两个功能有冲突吗?
谁能帮我解决这个问题?非常感谢。
我可以确认,在您的参数组合中第二次调用 setGroupHeaders
时,在某些列上设置了错误的 rowspan
属性值。我可以建议您在调用 setGroupHeaders
后手动解决问题。在你的族群中它将是
$("#list_invdate,#list_closed,#list_ship_via,#list_note,#list_name").attr("rowspan", "2");
查看修改后的演示 https://plnkr.co/edit/mNtUtkUCSh3WCFEtzjdu?p=preview
我正在使用 free-jqgrid v4.15.5,但工具栏搜索和 Header 分组有问题。
这是我正在使用的示例代码和问题
$(document).ready(function () {
var myData = [
{ id: "1", invdate: "2007-10-01", name: "test", note: "note", amount: "200.00", tax: "10.00", closed: true, ship_via: "TN", total: "210.00" },
{ id: "2", invdate: "2007-10-02", name: "test2", note: "note2", amount: "300.00", tax: "20.00", closed: false, ship_via: "FE", total: "320.00" },
{ id: "3", invdate: "2007-09-01", name: "test3", note: "note3", amount: "400.00", tax: "30.00", closed: false, ship_via: "FE", total: "430.00" },
{ id: "4", invdate: "2007-10-04", name: "test4", note: "note4", amount: "200.00", tax: "10.00", closed: true, ship_via: "TN", total: "210.00" },
{ id: "5", invdate: "2007-10-31", name: "test5", note: "note5", amount: "300.00", tax: "20.00", closed: false, ship_via: "FE", total: "320.00" },
{ id: "6", invdate: "2007-09-06", name: "test6", note: "note6", amount: "400.00", tax: "30.00", closed: false, ship_via: "FE", total: "430.00" },
{ id: "7", invdate: "2007-10-04", name: "test7", note: "note7", amount: "200.00", tax: "10.00", closed: true, ship_via: "TN", total: "210.00" },
{ id: "8", invdate: "2007-10-03", name: "test8", note: "note8", amount: "300.00", tax: "20.00", closed: false, ship_via: "FE", total: "320.00" },
{ id: "9", invdate: "2007-09-01", name: "test9", note: "note9", amount: "400.00", tax: "30.00", closed: false, ship_via: "TN", total: "430.00" },
{ id: "10", invdate: "2007-09-08", name: "test10", note: "note10", amount: "500.00", tax: "30.00", closed: true, ship_via: "TN", total: "530.00" },
{ id: "11", invdate: "2007-09-08", name: "test11", note: "note11", amount: "500.00", tax: "30.00", closed: false, ship_via: "FE", total: "530.00" },
{ id: "12", invdate: "2007-09-10", name: "test12", note: "note12", amount: "500.00", tax: "30.00", closed: false, ship_via: "FE", total: "530.00" }
],
myGrid = $("#list");
myGrid.jqGrid({
datatype: 'local',
data: myData,
colNames: ['Inv No', 'Date', 'Client', 'Amount', 'Tax', 'Total', 'Closed', 'Shipped via', 'Notes'],
colModel: [
{ name: 'id', index: 'id', width: 70, align: 'center', sorttype: 'int' },
{
name: 'invdate', index: 'invdate', width: 80, align: 'center', sorttype: 'date',
formatter: 'date', formatoptions: { newformat: 'd-M-Y' }, datefmt: 'd-M-Y'
},
{ name: 'name', index: 'name', width: 70 },
{ name: 'amount', index: 'amount', width: 100, formatter: 'number', align: 'right' },
{ name: 'tax', index: 'tax', width: 70, formatter: 'number', align: 'right' },
{ name: 'total', index: 'total', width: 120, formatter: 'number', align: 'right' },
{
name: 'closed', index: 'closed', width: 110, align: 'center', formatter: 'checkbox',
edittype: 'checkbox', editoptions: { value: 'Yes:No', defaultValue: 'Yes' },
stype: 'select', searchoptions: { sopt: ['eq', 'ne'], value: ':All;true:Yes;false:No' }
},
{
name: 'ship_via', index: 'ship_via', width: 120, align: 'center', formatter: 'select',
edittype: 'select', editoptions: { value: 'FE:FedEx;TN:TNT;IN:Intim', defaultValue: 'Intime' },
stype: 'select', searchoptions: { value: ':All;FE:FedEx;TN:TNT;IN:Intim' }
},
{ name: 'note', index: 'note', width: 100, sortable: false }
],
rowNum: 10,
rowList: [5, 10, 20],
//pager: '#pager',
gridview: true,
ignoreCase: true,
rownumbers: false,
sortname: 'invdate',
viewrecords: true,
sortorder: 'desc',
//caption: 'Just simple local grid',
height: '100%'
});
myGrid.jqGrid('filterToolbar', { stringResult: true, searchOnEnter: false, defaultSearch: "cn" });
myGrid.jqGrid('setGroupHeaders', {
useColSpanStyle: true, groupHeaders:
[
{ startColumnName: 'invdate', numberOfColumns: 5, titleText: "Group column 1" },
{ startColumnName: 'closed', numberOfColumns: 3, titleText: "Group column 2" },
]
});
});
如果有 只有一个 Header 分组级别
,则网格效果很好当我添加更多 Header 分组级别时,工具栏搜索出现问题
free-jqgrid的这两个功能有冲突吗?
谁能帮我解决这个问题?非常感谢。
我可以确认,在您的参数组合中第二次调用 setGroupHeaders
时,在某些列上设置了错误的 rowspan
属性值。我可以建议您在调用 setGroupHeaders
后手动解决问题。在你的族群中它将是
$("#list_invdate,#list_closed,#list_ship_via,#list_note,#list_name").attr("rowspan", "2");
查看修改后的演示 https://plnkr.co/edit/mNtUtkUCSh3WCFEtzjdu?p=preview