The usage of jsonmap with local data - free-jqgrid/jqGrid GitHub Wiki
Introduction.
jqGrid allows different sources to fill the grid. The input data will be get either from the server (see url
parameter and datatype: "json"
or datatype: "xml"
) or from input parameter data
(in case of datatype: "local"
) or datastr
(in case of datatype: "jsonstring"
or datatype: "xmlstring"
). In all cases with the exception of datatype: "json"
without loadonce: true
or datatype: "xml"
without loadonce: true
the input data will be saved inside of data
and _index
options of jqGrid.
To read the outer part of the input data jqGrid uses jsonReader
, localReader
or xmlReader
option. The main part of input data should be array of items. Every item provides information about the row displayed in the grid. To read the information from the item of input data and to bind it to the corresponding column of colModel
one uses either jsonmap
(or xmlmap
) property of colModel
or the name
alternatively.
For example, let us we use datatype: "json"
with loadonce: true
and we have items of input data in the following format
{ id: 123, name: { first: "Albert", last: "Einstein" }, birthday: "1879-03-14",
otherPropery: ... }
and we have the columns, First Name
, Last Name
and Full Name
defined as
{ name: "firstName", label: "First Name", jsonmap: "name.first" }
{ name: "lastName", label: "Last Name", jsonmap: "name.last" }
{ name: "fullName", label: "Full Name",
jsonmap: function (item) {
return item.name.first + " " + item.name.last
} }
After the first reading of the the server response jqGrid will save the results in _index
and data
internal parameter of jqGrid and will change datatype
from "json"
to "local"
. The items of data
array will be
{ _id_: "123", firstName: "Albert", lastName: "Einstein",
fullName: "Albert Einstein", birthday: "1879-03-14" }
No other properties as the names of colModel
will be saved in the items of data
.
After such reading of input data jqGrid allows to sort/filter/search without any additional request to the server.
The state of the problem in jqGrid 4.7 and earlier version
In case of usage datatype: "local"
jqGrid provides almost no mapping possibilities between the input data and the internal data. jqGrid expect that the names of properties of input data have one to one conformity with the values of name
property of colModel
. If the input data have nested structure one have to convert the data to flat model first and only then one can create the grid using input data
parameter with the flat data. Such scenario is especially uncomfortable if one use editing possibilities of jqGrid or if one need multiple time update the input data.
The solution of the problem implemented in free jqGrid 4.8
Free jqGrid 4.8 allows to distinguish the "local" jqGrid filled from the server in case of loadonce: true
scenario from direct filling of the grid using datatype: "local"
. In case of loadonce: true
free jqGrid 4.8 saves the original value of datatype
in the internal dataTypeOrg
option. It allows to ignore jsonmap
properties of colModel
in loadonce: true
scenario, but to use there in other cases of when we have datatype: "local"
.
The demo provides an example of usage nested input data with datatype: "local"
without making any changes in the input data.
The input information of the grid is the following array of items
var mydata = [
{ id: 10, name: {first: "Angela", last: "Merkel"},
address: { country: "Germany" },
birthday: "1954-07-17",
resume: [
{year: 1954, event: "born"},
{year: 2005, event: "Chancellor of Germany"}
] },
{ id: 20, name: {first: "Vladimir", last: "Putin"},
address: { country: "Russia" },
birthday: "1952-10-07",
resume: [
{year: 1952, event: "born"},
{year: 2000, event: "President of Russia"}
] },
{ id: 30, name: {first: "Barack", last: "Obama"},
address: { country: "USA" },
birthday: "1961-08-04",
resume: [
{year: 1961, event: "born"},
{year: 2008, event: "President of the United States of America"}
] }
];
The corresponding definition of colModel
is
colModel: [
{ name: "name",
jsonmap: function (item) {
return item.name.first + " " + item.name.last;
},
sorttype: function (cell) {
return cell.last + " " + cell.first;
} },
{ name: "country", jsonmap: "address.country",
sorttype: function (cell, item) {
return item.address.country;
} },
{ name: "birthday", formatter: "date", sorttype: "date",
formatoptions: { newformat: "d-M-Y" } }
]
(some less important properties of colModel
from the demo are not included above).