I have this simple function
function createGrid(limit){
$("#list").trigger("reloadGrid");
$("#list").jqGrid({
url:indexObj.gridUrl,
postData:{
"limit":limit
},
datatype: "json",
colNames:['ID','type','folder','Description'],
colModel:[
{name:'id',index:'id', width:50},
{name:'type',index:'type', width:100},
{name:'folder_id',index:'folder_id', width:100},
{name:'description',index:'description', width:200}
]
});
}
I first call it with limit = 1 and it calls the server and returns the right data. Then I call it with limit = 2 and it just reruns the previous ajax call (with limit=1) and returns the same data of course.
Why postData doesn't actually change? I see in fireBug that "limit" does have the correct value.
Using jqxGrid refresh and refreshdata does nothing for this.. What you need to do is get to the dataAdaptor you connected the jqxGrid to, and give it a MyDataAdaptor.dataBind (); and it will re-bind to the data, or in another description, re-issue the request to the server for the data and update its binding.
here you will get all your posted data in console.log (). Delete record is another common functionality in grid listing.You need to add delete call-back function into jQgrid instance and pass parameters like delete window header, send request on ENTER button clicked etc. //delete Options. save key parameter will keybind the Enter key to submit.
Refresh is used reload jQgrid table data, sometimes table is not refresh on action that time you need to refresh table data manually. jQgrid provide refresh: true property that enable to add refresh icon into footer of jQgrid table.You need to add this property into pager jqgrid instance.
first we will add a New record, Edit and Delete button into jQgrid table, we need to add 'true' property of add, edit, delete option which are associated with jQgrid instance, Change false to true property that will show add,edit and delete button into footer of jQgrid table, after required changes the previous code will become like below,
Or while reloading you can use setGridParam
for resetting postData
,
$("#list").jqGrid('setGridParam', {
postData: {"limit":limit }
}).trigger('reloadGrid');
And, you don't need to reinitialize/create jqGrid but you can simply use:
function createGrid(limit){
$("#list").trigger("reloadGrid");
#Code Goes here#
}
I'm not sure that the construct with such caching of the data is good, but nevertheless your current problem is clear.
It's important to understand that the call
$("#list").jqGrid({
url:indexObj.gridUrl,
...
});
creates the grid. It converts empty <table id="list"></table>
in very complex structure of divs and tables. So one can create the grid only once.
The grid consist from many parts (like headers) which don't need be recreated on the next filling of the grid. So jqGrid provides reloadGrid
event which can be triggered to refill the body of the grid. If jqGrid have postData
with some value like
postData: {
limit: limitVar
}
then if means that the object value of postData
will be created and initialized once with the current value of limitVar
variable. If you have outer variable (global, or defined in some outer scope) then you can use
postData: {
limit: function () { return limitVar; }
}
In the case you will have the current value of limitVar
as the value of limit
parameter of URL. By the way if the user just click on the column header, the grid need be sorted and jqGrid will make new HTTP request to url
. If you use function
inside of postData
then you will have the current value of limitVar
in the cases too.
If you will make less modification in your existing code then you can replace the line $("#list").trigger("reloadGrid");
(which is absolutely unneeded in the current code) to
$("#list").jqGrid("GridUnload");
It will destroy previously created structure of dives and tables (which build the grid) and creates an empty <table id="list"></table>
on the same place. So you can recreate the grid. Such code will work not so effectively, but it could be very helpful in some scenarios (see the answer and this one for example).
If you love us? You can donate to us via Paypal or buy me a coffee so we can maintain and grow! Thank you!
Donate Us With