This example demonstartes setting of common grid parameters.
After setting this parameters a Rows and Loading messages will be changed.
Reopen the grid to view this.Note that all parameters can be changed.
Set Common Params
HTML
...
Set Common Params
Java Scrpt code
...
jQuery("#params").jqGrid({
url:'server.php',
datatype: "xml",
colNames:['Inv No','Date', 'Client', 'Amount','Tax','Total','Notes'],
colModel:[
{name:'id',index:'id', width:55},
{name:'invdate',index:'invdate', width:90},
{name:'name',index:'name', width:100},
{name:'amount',index:'amount', width:80, align:"right"},
{name:'tax',index:'tax', width:80, align:"right"},
{name:'total',index:'total', width:80,align:"right"},
{name:'note',index:'note', width:150, sortable:false}
],
rowNum:10,
rowList:[10,20,30],
imgpath: gridimgpath,
pager: jQuery('#pparams'),
sortname: 'id',
mtype: "POST",
postData:{q:1},
viewrecords: true,
sortorder: "desc",
caption:"New Methods"
}).navGrid('#pparams',{edit:false,add:false,del:false});
jQuery("#pp1").click( function() {
$.extend($.jgrid.defaults,{recordtext: "Record(s)",loadtext: "Processing"});
alert("New parameters are set - reopen the grid");
});
PHP with MySQL
...
$page = $_GET['page']; // get the requested page
$limit = $_GET['rows']; // get how many rows we want to have into the grid
$sidx = $_GET['sidx']; // get index row - i.e. user click to sort
$sord = $_GET['sord']; // get the direction
if(!$sidx) $sidx =1;
// connect to the database
$db = mysql_connect($dbhost, $dbuser, $dbpassword)
or die("Connection Error: " . mysql_error());
mysql_select_db($database) or die("Error conecting to db.");
$result = mysql_query("SELECT COUNT(*) AS count FROM invheader a, clients b WHERE a.client_id=b.client_id");
$row = mysql_fetch_array($result,MYSQL_ASSOC);
$count = $row['count'];
if( $count >0 ) {
$total_pages = ceil($count/$limit);
} else {
$total_pages = 0;
}
if ($page > $total_pages) $page=$total_pages;
$start = $limit*$page - $limit; // do not put $limit*($page - 1)
$SQL = "SELECT a.id, a.invdate, b.name, a.amount,a.tax,a.total,a.note FROM invheader a, clients b WHERE a.client_id=b.client_id ORDER BY $sidx $sord LIMIT $start , $limit";
$result = mysql_query( $SQL ) or die("Couldnt execute query.".mysql_error());
if ( stristr($_SERVER["HTTP_ACCEPT"],"application/xhtml+xml") ) {
header("Content-type: application/xhtml+xml;charset=utf-8"); } else {
header("Content-type: text/xml;charset=utf-8");
}
$et = ">";
echo "";
echo "".$page."";
echo "".$total_pages."";
echo "".$count."";
// be sure to put text data in CDATA
while($row = mysql_fetch_array($result,MYSQL_ASSOC)) {
echo "";
echo "". $row[id]." | ";
echo "". $row[invdate]." | ";
echo " | ";
echo "". $row[amount]." | ";
echo "". $row[tax]." | ";
echo "". $row[total]." | ";
echo " | ";
echo "
";
}
echo "";
...