当我向jqgrid发送JSON响应时,我收到“未定义”消息,Firebug告诉我:
b.jgrid.formatter is undefined
[Break On This Error]
...input===true){b(".ui-pg-input",l).val(a.p.page);h=a.p.toppager?"#sp_1"+m+",#sp_1...
基本上没有告诉我太多。
当我发送空响应时会发生这种情况:
{"total":0,"page":1,"records":0,"rows":[]}
或回复记录。然后在网格中可以看到记录。在显示“未定义”消息后,我无法浏览页面,当然,代码中出现了错误。
正如@Oleg建议我在这里提供更多信息:
jquery.validate.min.js jquery.validate.unobtrusive.min.js jquery-1.5.1.min.js jquery-ui-1.8.11.min.js jquery.jqGrid.min.js ui/jquery.ui.core.js ui/jquery.ui.widget.js ui/jquery.ui.datepicker.js
var grid = jQuery("#list").jqGrid({ datatype: 'json', caption: 'Transaction Log', hiddengrid: 'true', postData: { companyId: function () { return $("#SelectedCompany").val(); }, userId: function () { return $("#SelectedUser").val(); }, dateFromString: function () { return $("#DateFrom").val(); }, dateToString: function () { return $("#DateTo").val(); } }, url: '@Url.Action("GetTransactionLogData")', mtype: 'GET', colNames: ['Ref.', 'TradeDate', 'Status', 'LegalEntity', ...], colModel: [ { name: 'Reference', index: 'Reference', width: '60' }, { name: 'TradeDate', index: 'TradeDate', width: '70' }, { name: 'Status', index: 'Status', width: '50' }, { name: 'LegalEntity', index: 'LegalEntity', width: '80' }, ... ], pager: $('#pager'), rowNum: 10, height: '100%' });
我该如何解决这个问题?
提前致谢。
答案 0 :(得分:30)
在 grid.locale-en.js
之前加入jquery.jqGrid.min.js
以使jqGrid正常工作非常重要。
此外,我建议您将gridview: true
选项添加到jqGrid并将pager: $('#pager')
替换为pager: '#pager'
,因为jqGrid只需要寻呼机的ID选择器。如果您使用pager: $('#pager')
,则jqGrid会将参数替换为pager: '#pager'
。因此,pager: $('#pager')
形式作为jqGrid参数确实毫无意义。