The first page of results with a jqgrid rowObject returns expected data but then returns incomplete data for subsequent pages of results. Why?
First
I suppose you use loadonce:true
option. It is one from the option which bring many problem (mostly understanding problems). The separation between local and remote data was clear before the introducing in the version 3.7 of jqGrid the new local sorting, paging and filtering (searching) features. Starting with jqGrid version 3.7 the loadonce:true
option allows you to have a mix between the remote data which you have at the first load and the local data which you have later. In another answer the close problem was already discussed. At the end of the loading process in case of the loadonce:true
option usage the datatype
of jqGrid will be changed to 'local'
. After that many things works different.
I suggest you to use jQuery.isArray(rowObject) as a quick and effective way to determine whether you should access rowObject
per integer index rowObject[3]
(if you access remote data) or per named property rowObject.projectId
.
You can see the whole local data with $("#list").jqGrid('getGridParam','data')
, which returns the array of all local rowObject
.
If the data which you need to access (rowObject[3]
) are not saved in the jqGrid in some column then you will not be able to see the information in the rowObject
. In the case you can use an additional hidden column for the data or save the data at the first load inside of loadComplete: function(data) { ... }
in any external object. You can test that $("#list").jqGrid('getGridParam','datatype')
is 'json'
(or 'xml'
depend on your server data) and if it true, you can save all data returned from the server which you need (from the 3-th column of the data
array) in an external array of object. So you will be able to access the data later inside your custom formatter.
UPDATED: The problem is solved in free jqGrid fork of jqGrid. The custom formatter (and cellattr
, rowattr
) contains still rowObject
parameter for compatibility reasons, but there are exist additional rowData
properties where the parsed data are saved as named properties:
formatter: function (cellValue, options, rowObject) {
// either rowObject[1] or rowObject.site_id,
// but options.rowData.site_id works ALWAYS
}
One can use
cellattr: function (rowid, cellValue, rowObject, cm, item) {
// either rowObject[1] or rowObject.site_id,
// but item.site_id works ALWAYS
}
in cellattr
.