How to use free jqGrid?

Free jqGrid is a JavaScript plugin that displays table-based data in a lot of different configurations. The data can be loaded from JavaScript array or be loaded from the server (in JSON or XML format). It supports client-side paging, sorting and filtering on server-side. One can group the displayed data, create the data as pivot table (made aggregation of data), display the data in the Tree form creates subgrids and so on. One can easily implement tree variants of editing of local or remote data. jQuery - Tutorial overview jqGrid Plugin

The large number of possibilities makes it difficult for a newcomer to start using jqGrid. The information below provides basic free jqGrid knowledge to make it easier to get started quickly. We will just include some small "advanced" options in some demos, mostly to show the diversity of customization possibilities.

The first grid

Free jqGrid is implemented as jQuery plugin, our plugin uses jQuery UI CSS or Bootstrap CSS for styling. Thus one would have to include the corresponding JavaScript and CSS files. The second basic thing, which one should know, is the fact that free jqGrid uses HTML <table> internally. One would have to create an empty <table> element to reserve the place where the grid should be created. Finally one should call jQuery("#tableId").jqGrid({/*options*/}); to create the grid. Different options of free jqGrid provides the data of the table body and the information about the outer part of the grid. For example, the code below

$(function(){
 "use strict";
 $("#grid").jqGrid({
 colModel:[
 { name:"firstName"},
 { name:"lastName"}
 ],
 data:[
 { id:10, firstName:"Angela", lastName:"Merkel"},
 { id:20, firstName:"Vladimir", lastName:"Putin"},
 { id:30, firstName:"David", lastName:"Cameron"},
 { id:40, firstName:"Barack", lastName:"Obama"},
 { id:50, firstName:"François", lastName:"Hollande"}
 ]
 });
});

creates the simple grid

firstName

lastName

Angela Merkel
Vladimir Putin
David Cameron
Barack Obama
François Hollande

The differences between free jqGrid and a standard HTML table are as follows:

  • Sortable Columns: One can click on the column header to sort the rows by the content in the column.
  • Hover Effects: Free jqGrid gives you the ability to use hovering effects for rows and the cells on the grid.
  • Selectable Rows: One can click on a row of the grid to select/unselect it
  • Multi-Selectable Rows: One can select multiple rows.
  • Selectable Rows: One can click on a row of the grid to select it.
  • Resizable Columns: One can resize the columns in an intuitive way, as shown in the animated image below.

Please use the demonstration grid above to sample just a few of the functionalities free jqGrid offers.

The full HTML page from the above example can look as following:

<!DOCTYPE html>
<htmllang="en">
<head>
 <metacharset="utf-8">
 <metahttp-equiv="X-UA-Compatible"content="IE=edge">
 <metaname="viewport"content="width=device-width,initial-scale=1">
 <title>Your page title</title>
 <linkrel="stylesheet"href="https://cdnjs.cloudflare.com/ajax/libs/jqueryui/1.11.4/themes/redmond/jquery-ui.min.css">
 <linkrel="stylesheet"href="https://cdnjs.cloudflare.com/ajax/libs/free-jqgrid/4.15.5/css/ui.jqgrid.min.css">
 <scriptsrc="https://cdnjs.cloudflare.com/ajax/libs/jquery/1.12.4/jquery.min.js"></script>
 <scriptsrc="https://cdnjs.cloudflare.com/ajax/libs/free-jqgrid/4.15.5/jquery.jqgrid.min.js"></script>
 <script>
 //<![CDATA[
 $(function(){
 "use strict";
 $("#grid").jqGrid({
 colModel:[
 { name:"firstName"},
 { name:"lastName"}
 ],
 data:[
 { id:10, firstName:"Angela", lastName:"Merkel"},
 { id:20, firstName:"Vladimir", lastName:"Putin"},
 { id:30, firstName:"David", lastName:"Cameron"},
 { id:40, firstName:"Barack", lastName:"Obama"},
 { id:50, firstName:"François", lastName:"Hollande"}
 ]
 });
 });
 //]]>
 </script>
</head>
<body>
<tableid="grid"></table>
</body>
</html>

You can try the example on JSFiddle.

It's important to understand that the empty <table> will be converted to relatively complex structure of divs and tables. One can use, for example, Chrome developer tools to examine the grid after creating:

One don't need to know all internals of the grid, but it's important to understand some basis facts:

  • every row of the grid (<tr> elements) have id attribute (see red marked attributes with the same values like we have in the input data: 10, 20). We will name the ids as rowids in the future. It's strictly recommended, that the input data contains id with unique values. In the way you will have the control over rowids, which will be used to identify the rows. If jqGrid will not find the id information in the input data, then it assign automaticaly the values "jqg1""jqg2""jqg2", ...
  • the first row of the grid have no data (see the box marked yellow), but the CSS property width will be assigned to every cell. The reason of such behavior: the usage table-layout: fixed; CSS property of the grid (<table>). It improves essencially the performance of the randering of the grid. On the other side the width of the columns is fixed and not depends on the width content of the cells.
  • The column headers are not the part of the <table>. jqGrid creates separete <div> (see the box marked in green) used named hDiv (header div) in difference to bDiv (body div) with the separate <table>, which conteins <table> with <thead> and <th> elements. The separation of the header and the body of the table is made because of the possibility to create the grid with the fixed height and vertical scrolling, which scrolls only the body holding the headers fixed.

jqGrid have a lot of different options, callback functions and events, which allows you full customize the behavior of the grid. One can for example create custom tooltip text or to remove it. One can prevent hovering or rows. One can prevent allow to select multiple rows, to prevert unselection of rows on the second click on previously seceted row, ... It's important curretly just to understand the basis features existing in every grid. The custumization of the features will be described later.

Type of data, templetes, formatters

The input data contains typically not only strings, but numbers, dates and so on. One uses typically some locale independend format for transfering the data (like 123456789.12345 for numbers, "2015-12-31""2015-12-31T07:08:45:15Z" and so on). One want typically display the data in some locale format (like 123,456,789.12 and "12/31/2015 8:45:15 AM"). Moreover the data in the column should be sorted based on the type of data and not as its locale string representation.

One can include in colModel additional properties, which specify the behavior specific for formatting, sorting editing and so on. For example, one can specify align:"center" or align:"right" to change the default alignment of the text in the cells. One can use width property, for example, width:300, to change the default width (150px) of the column. One can use sorttype:"number" in the column which holds numbers to change the default sorting befavior. One can use additionally property formatter:"number" to display the number using decimal and thousands separator specific for the current locale. The default locale included in jquery.jqgrid.min.js is en-US. There are 38 locales included in i18n folder. To include German locale one needs for example just include

<scriptsrc="https://cdnjs.cloudflare.com/ajax/libs/free-jqgrid/4.15.5/i18n/min/grid.locale-de.js"></script>

in the head of the page (before of after jquery.jqgrid.min.js).

Below is an example of the JavaScript code, which uses some features described above:

<!DOCTYPE html>
<htmllang="en">
<head>
 <metacharset="utf-8">
 <metahttp-equiv="X-UA-Compatible"content="IE=edge">
 <metaname="viewport"content="width=device-width,initial-scale=1">
 <title>Your page title</title>
 <linkrel="stylesheet"href="https://cdnjs.cloudflare.com/ajax/libs/jqueryui/1.11.4/themes/redmond/jquery-ui.min.css">
 <linkrel="stylesheet"href="https://cdnjs.cloudflare.com/ajax/libs/font-awesome/4.7.0/css/font-awesome.min.css">
 <linkrel="stylesheet"href="https://cdnjs.cloudflare.com/ajax/libs/free-jqgrid/4.15.5/css/ui.jqgrid.min.css">
 <scriptsrc="https://cdnjs.cloudflare.com/ajax/libs/jquery/1.12.4/jquery.min.js"></script>
 <scriptsrc="https://cdnjs.cloudflare.com/ajax/libs/free-jqgrid/4.15.5/jquery.jqgrid.min.js"></script>
 <script>
 //<![CDATA[
 $(function(){
 "use strict";
 $("#grid1").jqGrid({
 colModel:[
 { name:"name", label:"Client", width:53},
 { name:"invdate", label:"Date", width:75, align:"center", sorttype:"date",
 formatter:"date", formatoptions:{ newformat:"d-M-Y"}},
 { name:"amount", label:"Amount", width:65, template:"number"},
 { name:"tax", label:"Tax", width:41, template:"number"},
 { name:"total", label:"Total", width:51, template:"number"},
 { name:"closed", label:"Closed", width:59, template:"booleanCheckbox", firstsortorder:"desc"},
 { name:"ship_via", label:"Shipped via", width:87, align:"center", formatter:"select",
 formatoptions:{ value:"FE:FedEx;TN:TNT;DH:DHL", defaultValue:"DH"}}
 ],
 data:[
 { id:"10", invdate:"2015-10-01", name:"test", amount:""},
 { id:"20", invdate:"2015-09-01", name:"test2", amount:"300.00", tax:"20.00", closed:false, ship_via:"FE", total:"320.00"},
 { id:"30", invdate:"2015-09-01", name:"test3", amount:"400.00", tax:"30.00", closed:false, ship_via:"FE", total:"430.00"},
 { id:"40", invdate:"2015-10-04", name:"test4", amount:"200.00", tax:"10.00", closed:true, ship_via:"TN", total:"210.00"},
 { id:"50", invdate:"2015-10-31", name:"test5", amount:"300.00", tax:"20.00", closed:false, ship_via:"FE", total:"320.00"},
 { id:"60", invdate:"2015-09-06", name:"test6", amount:"400.00", tax:"30.00", closed:false, ship_via:"FE", total:"430.00"},
 { id:"70", invdate:"2015-10-04", name:"test7", amount:"200.00", tax:"10.00", closed:true, ship_via:"TN", total:"210.00"},
 { id:"80", invdate:"2015-10-03", name:"test8", amount:"300.00", tax:"20.00", closed:false, ship_via:"FE", total:"320.00"},
 { id:"90", invdate:"2015-09-01", name:"test9", amount:"400.00", tax:"30.00", closed:false, ship_via:"TN", total:"430.00"},
 { id:"100", invdate:"2015-09-08", name:"test10", amount:"500.00", tax:"30.00", closed:true, ship_via:"TN", total:"530.00"},
 { id:"110", invdate:"2015-09-08", name:"test11", amount:"500.00", tax:"30.00", closed:false, ship_via:"FE", total:"530.00"},
 { id:"120", invdate:"2015-09-10", name:"test12", amount:"500.00", tax:"30.00", closed:false, ship_via:"FE", total:"530.00"}
 ],
 iconSet:"fontAwesome",
 idPrefix:"g1_",
 rownumbers:true,
 sortname:"invdate",
 sortorder:"desc",
 caption:"The grid, which uses predefined formatters and templates"
 });
 });
 //]]>
 </script>
</head>
<body>
<tableid="grid1"></table>
</body>
</html>

You can try the example on JSFiddle.

The above code uses iconSet:"fontAwesome" and includes Font Awesome 4.x font-awesome.min.css additionally to CSSs included in the previous examples. You can see the resulting grid below:

The grid, which uses predefined formatters and templates

Client

Date

Amount

Tax

Total

Closed

Shipped via

1 test5 31-Oct-2015 300.00 20.00 320.00 FedEx
2 test4 04-Oct-2015 200.00 10.00 210.00 TNT
3 test7 04-Oct-2015 200.00 10.00 210.00 TNT
4 test8 03-Oct-2015 300.00 20.00 320.00 FedEx
5 test 01-Oct-2015 0.00 0.00 0.00 DHL
6 test12 10-Sep-2015 500.00 30.00 530.00 FedEx
7 test10 08-Sep-2015 500.00 30.00 530.00 TNT
8 test11 08-Sep-2015 500.00 30.00 530.00 FedEx
9 test6 06-Sep-2015 400.00 30.00 430.00 FedEx
10 test2 01-Sep-2015 300.00 20.00 320.00 DHL
11 test3 01-Sep-2015 400.00 30.00 430.00 FedEx
12 test9 01-Sep-2015 400.00 30.00 430.00 TNT

The meaning of the most of properties and options used in jqGrid can be guessed intuitively.

The option rownumbers:true creates additional column with the row numbers. The input data will be sorted by the invdate column displayed the latest dates first. Such behavior are defined by the options sortname:"invdate" and sortorder:"desc". The caption option defines the text on the title of the grid. By default the title contains the button, which allows to collapse/expand the grid. If you don't want to have the button you need to include additional option hidegrid:false. It's the main principle of jqGrid. It contains many options which allows to customize the default behavior. Thus if you see some element of the grid which you don't like then probably there are exist an additional option which allows you to remove the element or to change its behavior.

The option idPrefix:"g1_" is important because we use the data with the same id values in multiple grids on the page. The id arrtibute of every row <tr> of the grid will be assign based on the value of id property of input data. The usage of idPrefix:"g1_" force prefixing of id values. As the result the rows of the grid will have rowids "g1_10""g1_20", ... instead of "10""20", ... used in the first demo. It prevents from id duplicates, prohibited in HTML.

The label property defines the column header. If no label is defined then the name property will be used in the column header.

The columns invdate and ship_via used formatters "date" and "select". The options of the formatters are defined using formatoptions.

The input data of the column ship_via contains the values "FE""TN" or "DH". The values will be displayed as "FedEx""TNT" or "DHL" based on the value property of the formatoptions. The first item of data don't conatins and ship_via property and the grid displays "DHL" for the item based on the property defaultValue:"DH" of the formatoptions.

The input data of the column invdate contains the date in ISO 8601 format (for example "2015-10-31"). The formatoptions contains newformat:"d-M-Y", which specifys the format of the data displayed as 31-Oct-2015. The value of newformat corresponds formatting of the date in PHP (see here). If we would remove the property formatoptions:{ newformat:"d-M-Y"} then the date will be displayed as 10/31/2015 in case of usage default en-US locale or as 31.10.2015 if we would include the German locale grid.locale-de.min.js. The locale file specifys the default format of the date, but one can still use formatoptions.newformat to display dates in another format, which we prefer for the column. By the way the ISO 8601 is the deafult input format used by formatter:"date", but one can use srcformat property of formatoptions to be able to process the data correctly if the input data contains another input format. For example, we can use formatoptions:{ srcformat:"u1000", newformat:"d.m.Y H:i:s"} to decode the timestamp 1450956451996 in the form 24.12.201512:27:31. The formatter just changes the fprmat of data displayed in the column. The property sorttype:"date" informs jqGrid to sort the contain the column by date instead of comparing the texts.

We included the details of formatter:"date" and formatter:"select" just as examples of predefined formatters. Every formatter support its own specific options, which can be specified in formatoptions. There are some typical set of column properties, which will be typically used together. For example, very common settings are formatter:"number", align:"right", sorttype:"number" in case of usage numbers as input data. The property template:"number" is the shortcut, which allows to specify all the options (and some other used for searching and editing) at once. We use the template for columns amountamount and total.

The column closed uses one more template: template:"booleanCheckbox", which displays Boolean input data true and false as or in case of usage iconSet:"fontAwesome". The property firstsortorder:"desc" force to start sorting of the column by descending oder, where the checked items (true) will be displayed first. The second click on the column header of the column closed will invert the sorting order. The property firstsortorder:"desc" is practical, because one want typecally see checked items if one sort by the column with Bollean data.

Usage of Boostrap CSS instead of jQuery UI CSS

Free jqGrid can use Boostrap CSS instead of default jQuery UI CSS. One need just need include Boostrap CSS and to add guiStyle:"bootstrap" option. The code posted in the previous section can look as the following:

<!DOCTYPE html>
<htmllang="en">
<head>
 <metacharset="utf-8">
 <metahttp-equiv="X-UA-Compatible"content="IE=edge">
 <metaname="viewport"content="width=device-width,initial-scale=1">
 <title>Your page title</title>
 <linkrel="stylesheet"href="https://cdnjs.cloudflare.com/ajax/libs/font-awesome/4.7.0/css/font-awesome.min.css">
 <linkrel="stylesheet"href="https://cdnjs.cloudflare.com/ajax/libs/twitter-bootstrap/3.3.7/css/bootstrap.min.css">
 <linkrel="stylesheet"href="https://cdnjs.cloudflare.com/ajax/libs/twitter-bootstrap/3.3.7/css/bootstrap-theme.min.css">
 <linkrel="stylesheet"href="https://cdnjs.cloudflare.com/ajax/libs/free-jqgrid/4.15.5/css/ui.jqgrid.min.css">
 <scriptsrc="https://cdnjs.cloudflare.com/ajax/libs/jquery/1.12.4/jquery.min.js"></script>
 <scriptsrc="https://cdnjs.cloudflare.com/ajax/libs/twitter-bootstrap/3.3.7/js/bootstrap.min.js"></script>
 <scriptsrc="https://cdnjs.cloudflare.com/ajax/libs/free-jqgrid/4.15.5/jquery.jqgrid.min.js"></script>
 <script>
 //<![CDATA[
 $(function(){
 "use strict";
 $("#grid1b").jqGrid({
 colModel:[
 { name:"name", label:"Client", width:53},
 { name:"invdate", label:"Date", width:75, align:"center", sorttype:"date",
 formatter:"date", formatoptions:{ newformat:"d-M-Y"}},
 { name:"amount", label:"Amount", width:65, template:"number"},
 { name:"tax", label:"Tax", width:41, template:"number"},
 { name:"total", label:"Total", width:51, template:"number"},
 { name:"closed", label:"Closed", width:59, template:"booleanCheckbox", firstsortorder:"desc"},
 { name:"ship_via", label:"Shipped via", width:87, align:"center", formatter:"select",
 formatoptions:{ value:"FE:FedEx;TN:TNT;DH:DHL", defaultValue:"DH"}}
 ],
 data:[
 { id:"10", invdate:"2015-10-01", name:"test", amount:""},
 { id:"20", invdate:"2015-09-01", name:"test2", amount:"300.00", tax:"20.00", closed:false, ship_via:"FE", total:"320.00"},
 { id:"30", invdate:"2015-09-01", name:"test3", amount:"400.00", tax:"30.00", closed:false, ship_via:"FE", total:"430.00"},
 { id:"40", invdate:"2015-10-04", name:"test4", amount:"200.00", tax:"10.00", closed:true, ship_via:"TN", total:"210.00"},
 { id:"50", invdate:"2015-10-31", name:"test5", amount:"300.00", tax:"20.00", closed:false, ship_via:"FE", total:"320.00"},
 { id:"60", invdate:"2015-09-06", name:"test6", amount:"400.00", tax:"30.00", closed:false, ship_via:"FE", total:"430.00"},
 { id:"70", invdate:"2015-10-04", name:"test7", amount:"200.00", tax:"10.00", closed:true, ship_via:"TN", total:"210.00"},
 { id:"80", invdate:"2015-10-03", name:"test8", amount:"300.00", tax:"20.00", closed:false, ship_via:"FE", total:"320.00"},
 { id:"90", invdate:"2015-09-01", name:"test9", amount:"400.00", tax:"30.00", closed:false, ship_via:"TN", total:"430.00"},
 { id:"100", invdate:"2015-09-08", name:"test10", amount:"500.00", tax:"30.00", closed:true, ship_via:"TN", total:"530.00"},
 { id:"110", invdate:"2015-09-08", name:"test11", amount:"500.00", tax:"30.00", closed:false, ship_via:"FE", total:"530.00"},
 { id:"120", invdate:"2015-09-10", name:"test12", amount:"500.00", tax:"30.00", closed:false, ship_via:"FE", total:"530.00"}
 ],
 guiStyle:"bootstrap",
 iconSet:"fontAwesome",
 idPrefix:"gb1_",
 rownumbers:true,
 sortname:"invdate",
 sortorder:"desc",
 caption:"The grid, which uses predefined formatters and templates"
 });
 });
 //]]>
 </script>
</head>
<body>
<tableid="grid1b"></table>
</body>
</html>

The resulting grid will be:

The grid, which uses predefined formatters and templates

Client

Date

Amount

Tax

Total

Closed

Shipped via

1 test5 31-Oct-2015 300.00 20.00 320.00 FedEx
2 test4 04-Oct-2015 200.00 10.00 210.00 TNT
3 test7 04-Oct-2015 200.00 10.00 210.00 TNT
4 test8 03-Oct-2015 300.00 20.00 320.00 FedEx
5 test 01-Oct-2015 0.00 0.00 0.00 DHL
6 test12 10-Sep-2015 500.00 30.00 530.00 FedEx
7 test10 08-Sep-2015 500.00 30.00 530.00 TNT
8 test11 08-Sep-2015 500.00 30.00 530.00 FedEx
9 test6 06-Sep-2015 400.00 30.00 430.00 FedEx
10 test2 01-Sep-2015 300.00 20.00 320.00 FedEx
11 test3 01-Sep-2015 400.00 30.00 430.00 FedEx
12 test9 01-Sep-2015 400.00 30.00 430.00 TNT

Free jqGrid allows to customize the results. By adding the following CSS rules for example

.ui-jqgrid.ui-jqgrid-bootstrap {
 border:1px solid #003380;
}
.ui-jqgrid.ui-jqgrid-bootstrap .ui-jqgrid-caption {
 background-color:#e6f0ff;
}
.ui-jqgrid.ui-jqgrid-bootstrap .ui-jqgrid-hdiv {
 background-color:#cce0ff;
}

one gets the following results

The grid, which uses predefined formatters and templates

Client

Date

Amount

Tax

Total

Closed

Shipped via

1 test5 31-Oct-2015 300.00 20.00 320.00 FedEx
2 test4 04-Oct-2015 200.00 10.00 210.00 TNT
3 test7 04-Oct-2015 200.00 10.00 210.00 TNT
4 test8 03-Oct-2015 300.00 20.00 320.00 FedEx
5 test 01-Oct-2015 0.00 0.00 0.00 DHL
6 test12 10-Sep-2015 500.00 30.00 530.00 FedEx
7 test10 08-Sep-2015 500.00 30.00 530.00 TNT
8 test11 08-Sep-2015 500.00 30.00 530.00 FedEx
9 test6 06-Sep-2015 400.00 30.00 430.00 FedEx
10 test2 01-Sep-2015 300.00 20.00 320.00 FedEx
11 test3 01-Sep-2015 400.00 30.00 430.00 FedEx
12 test9 01-Sep-2015 400.00 30.00 430.00 TNT

We removed the option iconSet:"fontAwesome" in the last example additionally, to show that the default value of iconSet option is iconSet:"glyph" (instead of iconSet:"jQueryUI") in case of usage Bootstrap CSS.

To use Bootstrap 4 instead of Bootstrap 3 one need just to replace guiStyle:"bootstrap" parameter to guiStyle:"bootstrap4". jqGrid uses only Bootstrap CSS and no JavaScript files of Bootsrap, but if you do need bootstrap.min.js then you need to include both popper.min.js and bootstrap.min.js. Be carefull, that jqGrid can't be used with slim version of jQuery. One need to include the full version instead. The resulting code could be the following, for example:

<!DOCTYPE html>
<htmllang="en">
<head>
 <metacharset="utf-8">
 <metahttp-equiv="X-UA-Compatible"content="IE=edge">
 <metaname="viewport"content="width=device-width,initial-scale=1">
 <title>Demo which uses Bootstrap 4</title>
 <linkrel="stylesheet"crossorigin="anonymous"
 href="https://cdnjs.cloudflare.com/ajax/libs/twitter-bootstrap/4.1.3/css/bootstrap.min.css"
 integrity="sha256-eSi1q2PG6J7g7ib17yAaWMcrr5GrtohYChqibrV7PBE=">
 <linkrel="stylesheet"crossorigin="anonymous"
 href="https://cdnjs.cloudflare.com/ajax/libs/font-awesome/4.7.0/css/font-awesome.min.css"
 integrity="sha256-eZrrJcwDc/3uDhsdt61sL2oOBY362qM3lon1gyExkL0=">
 <linkrel="stylesheet"crossorigin="anonymous"
 href="https://cdnjs.cloudflare.com/ajax/libs/free-jqgrid/4.15.5/css/ui.jqgrid.min.css"
 integrity="sha256-3oIi71IMpsoA+8ctSTIM+6ScXYjyZEV06q6bbK6CjsM=">
 <scriptcrossorigin="anonymous"src="https://code.jquery.com/jquery-3.3.1.min.js"
 integrity="sha256-FgpCb/KJQlLNfOu91ta32o/NMZxltwRo8QtmkMRdAu8="></script>
 <!-- the next line need be uncommented if you need to use bootstrap.min.js -->
 <!--<script crossorigin="anonymous"
 src="https://cdnjs.cloudflare.com/ajax/libs/popper.js/1.14.3/umd/popper.min.js"
 integrity="sha256-98vAGjEDGN79TjHkYWVD4s87rvWkdWLHPs5MC3FvFX4="></script>
 <script crossorigin="anonymous"
 src="https://cdnjs.cloudflare.com/ajax/libs/twitter-bootstrap/4.1.3/js/bootstrap.min.js"
 integrity="sha256-VsEqElsCHSGmnmHXGQzvoWjWwoznFSZc6hs7ARLRacQ="></script>-->
 <script>
 $.jgrid = $.jgrid ||{};
 $.jgrid.no_legacy_api =true;
 </script>
 <scriptcrossorigin="anonymous"
 src="https://cdnjs.cloudflare.com/ajax/libs/free-jqgrid/4.15.5/jquery.jqgrid.min.js"
 integrity="sha256-ELi2cs17gL2MqNzkRkogxZsVLmL+oWfeVOwZQLcp8ek="></script>
 <script>
 //<![CDATA[
 $(function(){
 "use strict";
 $("#grid1b").jqGrid({
 colModel:[
 { name:"name", label:"Client", width:53},
 { name:"invdate", label:"Date", width:75, align:"center", sorttype:"date",
 formatter:"date", formatoptions:{ newformat:"d-M-Y"}},
 { name:"amount", label:"Amount", width:65, template:"number"},
 { name:"tax", label:"Tax", width:41, template:"number"},
 { name:"total", label:"Total", width:51, template:"number"},
 { name:"closed", label:"Closed", width:59, template:"booleanCheckbox", firstsortorder:"desc"},
 { name:"ship_via", label:"Shipped via", width:87, align:"center", formatter:"select",
 formatoptions:{ value:"FE:FedEx;TN:TNT;DH:DHL", defaultValue:"DH"}}
 ],
 data:[
 { id:"10", invdate:"2015-10-01", name:"test", amount:""},
 { id:"20", invdate:"2015-09-01", name:"test2", amount:"300", tax:"20", closed:false, ship_via:"FE", total:"320"},
 { id:"30", invdate:"2015-09-01", name:"test3", amount:"400", tax:"30", closed:false, ship_via:"FE", total:"430"},
 { id:"40", invdate:"2015-10-04", name:"test4", amount:"200", tax:"10", closed:true, ship_via:"TN", total:"210"},
 { id:"50", invdate:"2015-10-31", name:"test5", amount:"300", tax:"20", closed:false, ship_via:"FE", total:"320"},
 { id:"60", invdate:"2015-09-06", name:"test6", amount:"400", tax:"30", closed:false, ship_via:"FE", total:"430"},
 { id:"70", invdate:"2015-10-04", name:"test7", amount:"200", tax:"10", closed:true, ship_via:"TN", total:"210"},
 { id:"80", invdate:"2015-10-03", name:"test8", amount:"300", tax:"20", closed:false, ship_via:"FE", total:"320"},
 { id:"90", invdate:"2015-09-01", name:"test9", amount:"400", tax:"30", closed:false, ship_via:"TN", total:"430"},
 { id:"100", invdate:"2015-09-08", name:"test10", amount:"500", tax:"30", closed:true, ship_via:"TN", total:"530"},
 { id:"110", invdate:"2015-09-08", name:"test11", amount:"500", tax:"30", closed:false, ship_via:"FE", total:"530"},
 { id:"120", invdate:"2015-09-10", name:"test12", amount:"500", tax:"30", closed:false, ship_via:"FE", total:"530"}
 ],
 guiStyle:"bootstrap4",
 iconSet:"fontAwesome",
 idPrefix:"gb1_",
 rownumbers:true,
 sortname:"invdate",
 sortorder:"desc",
 caption:"The grid, which uses predefined formatters and templates"
 });
 });
 //]]>
 </script>
</head>
<body>
<tableid="grid1b"></table>
</body>
</html>

See JSFiddle demo.

Paging, searching, filtering

Paging, searching and filtering are extreamly important in case of displaying large set of information. One should understand that displaying thousands or rows of the data have no value for the user. The user need to know only some small subset from the data, like top 10 rows sorted based on some criteria. The posibility of paging (showing the next 10 rows from top 20) is absolutely enough in the most realistic scenarios. Sometimes one need to filter the data first of all based on one criterias (like get the data from the last month) and then to sort the result based on another criterias and display the final result using the paging.

The next paragraphs gives small infroduction of the paging, searching and filtering features of free jqGrid. We will describe all the features based on local data, but jqGrid supports the same features with remote data too.

Paging

Sometime one need to dispaly so many items of data that display not allows to represent. In such case it would be much more effective to use local paging of data instead of displaying all the items on the page and to require that the user uses vertical scrollbar to see the data. Placing of all the data on the HTML page takes relative much time and it makes the page very slow (less responsive). We can modify the above example by adding toppager:truepager:true and rowNum:5 to have the following grid:

The grid demonstrates formatters, templates and the pager

Page  of 3

Client

Date

Amount

Tax

Total

Closed

Shipped via

1 test5 31-Oct-2015 300.00 20.00 320.00 FedEx
2 test4 04-Oct-2015 200.00 10.00 210.00 TNT
3 test7 04-Oct-2015 200.00 10.00 210.00 TNT
4 test8 03-Oct-2015 300.00 20.00 320.00 FedEx
5 test 01-Oct-2015 0.00 0.00 0.00 DHL
Page  of 3

The option toppager:true adds the pager on top of the grid, the option pager:true adds the bottom pager and rowNum:5 specifies the size to the page. One can use additional viewrecords:true option to display the status of the page in the right part of the pagers. One can use page:2 to specify the page number displayed initially:

The grid demonstrates formatters, templates and the pager

Page  of 3
View 6 - 10 of 12

Client

Date

Amount

Tax

Total

Closed

Shipped via

6 test12 10-Sep-2015 500.00 30.00 530.00 FedEx
7 test10 08-Sep-2015 500.00 30.00 530.00 TNT
8 test11 08-Sep-2015 500.00 30.00 530.00 FedEx
9 test6 06-Sep-2015 400.00 30.00 430.00 FedEx
10 test2 01-Sep-2015 300.00 20.00 320.00 DHL
Page  of 3
View 6 - 10 of 12

One uses page:2 seldom. It's just important don't mix pager and page properties.

The pager have the bottons (the first), (the previous), (the next) and (the last), which allow to navigate over the pages. The additional <input> element allows to navigate to some page directly by the number.

Sorting

There are two main options of jqGrid, which specify sorting: sortname and sortorder. The default value of sortname is the empty string, which means the the grid will be displayed unsorted. It means that the order of rows corresponds the order of items in the array of item of the input data. If the sortname is specified, for example sortname:"invdate", then the grid sorts the data first comparing the property invdate of the input data. By default the values of the property will be compared as strings. It would be good enough if we would use ISO date format like "2015-10-31", but it would be wrong in more common case. The comparing of strings is case insensitive by default, but one can change the behafior by usage ignoreCase:false option. One can include in the column sorttype with one from predefined values ("integer""number" and "date") which will change the default sorttype:"text". One can define sorttype as function or specify the callback function sortfunc, which gives you the maximal control over comparing the items.

By default clicking on the column header will change the sorting column or to invert the sort order. The usage of threeStateSort:true changes the behavior so that the 3-d click on the column header makes the grid unsorted. You can try the 3-state behavior of sorting on the next grid, where we added the option sortIconsBeforeText:true, which places the sorting icons before the text of the column header. It could be practical if one prefere to display the sorting icons even if the column width so small that the text of the column header couldn't be full displayed together with the corting icon.

The grid demonstrates formatters, templates and the pager

Page  of 3
View 1 - 5 of 12

Client

Date

Amount

Tax

Total

Closed

Shipped via

1 test5 31-Oct-2015 300.00 20.00 320.00 FedEx
2 test4 04-Oct-2015 200.00 10.00 210.00 TNT
3 test7 04-Oct-2015 200.00 10.00 210.00 TNT
4 test8 03-Oct-2015 300.00 20.00 320.00 FedEx
5 test 01-Oct-2015 0.00 0.00 0.00 DHL
Page  of 3
View 1 - 5 of 12

We included in the grid one more option headertitles:true, which creates the tooltips on column headers. It's practical if one

There are some other advanced options like multiSort:true, which allows to sort by multiple columns and some options, which customize the look of the sorting icons. The option viewsortcols and ovewriding $.jgrid.builderSortIcons method allows to implement more advanced scenarios.

Filtering

Filtering is very practical and powerful feature of jqGrid. One can create an additional line with input elements which allows to filter the grid data by specified values. One need just call of the method filterToolbar.

The grid demonstrates formatters, templates and the pager

Page  of 3
View 1 - 5 of 12

Client

Date

Amount

Tax

Total

Closed

Shipped via

×
×
×
×
×
1 test5 31-Oct-2015 300.00 20.00 320.00 FedEx
2 test4 04-Oct-2015 200.00 10.00 210.00 TNT
3 test7 04-Oct-2015 200.00 10.00 210.00 TNT
4 test8 03-Oct-2015 300.00 20.00 320.00 FedEx
5 test 01-Oct-2015 0.00 0.00 0.00 DHL
Page  of 3
View 1 - 5 of 12

The code of the above example is almost the same as in the previous one. The following changes are made:

  • The call of the method filterToolbar is added.
  • The option searching:{ defaultSearch:"cn"} is added. It sepecify the default options of searching. By default jqGrid filters by "bw" (begin with) compare operator. The option defaultSearch:"cn" changes the default behavior to "contain" operator.
  • The property searchoptions:{ sopt:["eq"]} are added in the column with the date to change the default "contain" operator used for filtering to "equal to" operator in the column.
  • The properties stype:"select", searchoptions:{ value:":Any;FE:FedEx;TN:TNT;DH:DHL"} are added in the last column. It creates the select in the filter toolbar with the options "Any""FedEx""TNT" and "DHL", where choosing of "Any" will shich off the filtering by the column. The property searchoptions.value contains semicolon separated string, where the subtrings like FE:FedEx specify the value and the text of the option: <optionvalue="FE">FedEx</option>. The substring :Any creates the option <optionvalue="">Any</option> with empty value, which will be interpreted as no filtering.

One can find the full code of the above demo below:

$(function(){
 "use strict";
 $("#grid5").jqGrid({
 colModel:[
 { name:"name", label:"Client", width:53},
 { name:"invdate", label:"Date", width:90, align:"center", sorttype:"date",
 formatter:"date", formatoptions:{ newformat:"d-M-Y"},
 searchoptions:{ sopt:["eq"]}},
 { name:"amount", label:"Amount", width:65, template:"number"},
 { name:"tax", label:"Tax", width:41, template:"number"},
 { name:"total", label:"Total", width:51, template:"number"},
 { name:"closed", label:"Closed", width:59, template:"booleanCheckbox", firstsortorder:"desc"},
 { name:"ship_via", label:"Shipped via", width:87, align:"center",
 formatter:"select",
 formatoptions:{ value:"FE:FedEx;TN:TNT;DH:DHL", defaultValue:"DH"},
 stype:"select",
 searchoptions:{ value:":Any;FE:FedEx;TN:TNT;DH:DHL"}}
 ],
 data:[
 { id:"10", invdate:"2015-10-01", name:"test", amount:""},
 { id:"20", invdate:"2015-09-01", name:"test2", amount:"300.00", tax:"20.00", closed:false, ship_via:"DH", total:"320.00"},
 { id:"30", invdate:"2015-09-01", name:"test3", amount:"400.00", tax:"30.00", closed:false, ship_via:"FE", total:"430.00"},
 { id:"40", invdate:"2015-10-04", name:"test4", amount:"200.00", tax:"10.00", closed:true, ship_via:"TN", total:"210.00"},
 { id:"50", invdate:"2015-10-31", name:"test5", amount:"300.00", tax:"20.00", closed:false, ship_via:"FE", total:"320.00"},
 { id:"60", invdate:"2015-09-06", name:"test6", amount:"400.00", tax:"30.00", closed:false, ship_via:"FE", total:"430.00"},
 { id:"70", invdate:"2015-10-04", name:"test7", amount:"200.00", tax:"10.00", closed:true, ship_via:"TN", total:"210.00"},
 { id:"80", invdate:"2015-10-03", name:"test8", amount:"300.00", tax:"20.00", closed:false, ship_via:"FE", total:"320.00"},
 { id:"90", invdate:"2015-09-01", name:"test9", amount:"400.00", tax:"30.00", closed:false, ship_via:"TN", total:"430.00"},
 { id:"100", invdate:"2015-09-08", name:"test10", amount:"500.00", tax:"30.00", closed:true, ship_via:"TN", total:"530.00"},
 { id:"110", invdate:"2015-09-08", name:"test11", amount:"500.00", tax:"30.00", closed:false, ship_via:"FE", total:"530.00"},
 { id:"120", invdate:"2015-09-10", name:"test12", amount:"500.00", tax:"30.00", closed:false, ship_via:"FE", total:"530.00"}
 ],
 iconSet:"fontAwesome",
 idPrefix:"g5_",
 rownumbers:true,
 sortname:"invdate",
 sortorder:"desc",
 threeStateSort:true,
 sortIconsBeforeText:true,
 headertitles:true,
 toppager:true,
 pager:true,
 rowNum:5,
 viewrecords:true,
 searching:{
 defaultSearch:"cn"
 },
 caption:"The grid, which demonstrates formatters, templates and the pager"
 }).jqGrid("filterToolbar");
});

Remark: we added the CSS rule

.ui-search-input > input::-ms-clear {
 display: none;
}

to remove additional "clear field", which will be displayed in <input> elements by default in Internet Explorer (see IE documentation).

We don't want to include too much details in the "Getting started" toptic. Nevertherless we would like to include one more small example, which shows the main way to integration any well-known conrols in the filter toolbar of jqGrid. One can specify dataInit callback inside of searchoptions property of some column. For example we can use jQuery UI Datepicker in the "Date" column in the following way. We need modify searchoptions:{ sopt:["eq"]} property to the following:

searchoptions:{
 sopt:["eq"],
 dataInit:function(elem, options){
 var self =this, $elem = $(elem),
 filterOnSelect =function(){
 setTimeout(function(){
 self.triggerToolbar();
 },50);
 },
 triggerInputChangeOnSelect =function(){
 $elem.change();
 };
 setTimeout(function(){
 $elem.datepicker({
 dateFormat:"dd-M-yy",
 autoSize:true,
 changeYear:true,
 changeMonth:true,
 showButtonPanel:true,
 showWeek:true,
 onSelect:(options.mode ==="filter"? filterOnSelect : triggerInputChangeOnSelect)
 });
 },50);
 }
}

The grid demonstrates formatters, templates and the pager

Page  of 3
View 1 - 5 of 12

Client

Date

Amount

Tax

Total

Closed

Shipped via

×
×
×
×
×
1 test5 31-Oct-2015 300.00 20.00 320.00 FedEx
2 test4 04-Oct-2015 200.00 10.00 210.00 TNT
3 test7 04-Oct-2015 200.00 10.00 210.00 TNT
4 test8 03-Oct-2015 300.00 20.00 320.00 FedEx
5 test 01-Oct-2015 0.00 0.00 0.00 DHL
Sign up and earn $1000 a day ⋙

5 Ways AI is Transforming the Sports Betting Industry

5 Ways AI is Transforming the Sports Betting Industry

The sports betting industry is undergoing a significant transformation thanks to artificial intelligence (AI) advancements. Bettors no longer have to rely on gut feelings or basic statistics; AI is changing the game.

Creative Projects: Fun DIY Ideas Using Your Phone and PC

Creative Projects: Fun DIY Ideas Using Your Phone and PC

Here are some fun DIY projects you can try using these gadgets alone. After using your Bob Casino login to play your favorite betting games, you’ll feel so refreshed, that you can dive in and get those creative juices directly flowing!

Things to Know About Slots

Things to Know About Slots

Before beginning to play slot PGBET, there are a few things you should understand to help make informed decisions and maximize enjoyment. Knowing these details will enable you to make better choices and have more fun!

Mahjong Mastery: A Beginners Guide to Success with BONS Casino

Mahjong Mastery: A Beginners Guide to Success with BONS Casino

Embark on your mahjong journey with confidence using this comprehensive beginner's guide from BONS Casino. Learn the master essential strategies.

Understanding eSports betting: everything that beginners want to know

Understanding eSports betting: everything that beginners want to know

eSports betting is fascinating and very entertaining, and for those of you who are now getting started with it, learning the basics and understanding the most important betting markets is paramount to help you succeed.

Summary of ways to use Game Bar on Windows 10

Summary of ways to use Game Bar on Windows 10

Summary of ways to use Game Bar on Windows 10, How to use Xbox Game Bar on Windows 10 is a question that many people are interested in. Join WebTech360

Counter-Strike: Global Offensive - PC Configuration for CSGO

Counter-Strike: Global Offensive - PC Configuration for CSGO

CSGO is a famous shooting strategy in the game. So let's explore the details of this game and configure the CS GO gaming computer.

Configure Mortal Kombat 11 game settings for computers

Configure Mortal Kombat 11 game settings for computers

Mortal Kombat 11 is a fighting game version that attracts a large number of players. To be able to play the game, you will need to learn about its settings.

Social Aspects of Sports Betting: Balancing Fun and Responsibility

Social Aspects of Sports Betting: Balancing Fun and Responsibility

Sports betting has become a popular form of entertainment and a lucrative industry across the globe. From the glitz and glamour of Las Vegas casinos to the convenience of online platforms, millions of people engage in sports betting for the thrill of the game and the potential to win big. 

Guide to Install LoL Configuration: Wild Rift Play Smoothly on PC

Guide to Install LoL Configuration: Wild Rift Play Smoothly on PC

After many days of anticipation, League of Legends: Wild Rift Mobile version released by VNG can be officially downloaded on both Android and iOS.

Reference Top 7 Best PC Strategy Games 2023

Reference Top 7 Best PC Strategy Games 2023

Want to find interesting computer games? The following article will introduce you to some of the best PC strategy games.

Top 5 Best Sniper Games For PC 2023 You Shouldnt Miss

Top 5 Best Sniper Games For PC 2023 You Shouldnt Miss

Shooting game, becoming a sniper, you definitely can't miss the following sniper games for PC. Let's find out with WebTech360!

Top 16 Best Racing Games For Computers and Phones You Probably Didnt Know

Top 16 Best Racing Games For Computers and Phones You Probably Didnt Know

If you want to fix your computer lag or slowness when playing games, let's join WebTech360 to refer to the top 6 best PC game acceleration software!

Summary of 5 Best PC Game Accelerator, Lag Reduction Software 2023

Summary of 5 Best PC Game Accelerator, Lag Reduction Software 2023

If you want to fix your computer lag or slowness when playing games, let's join WebTech360 to refer to the top 6 best PC game acceleration software!

Top 10 Best PC MOBA Games 2023 You Should Try

Top 10 Best PC MOBA Games 2023 You Should Try

Let's explore the best Moba game on PC with WebTech360 to try to choose the right one for your own preferences right through this article.

Top 10 Lightest PC Games For Young People Most Loved Today

Top 10 Lightest PC Games For Young People Most Loved Today

Light game for PC is the most searched keyword phrase on today's social networking sites and forums. So what are the best PC entertainment titles?

Top 10 Best Offline Games For IOS You Cant Miss 2023

Top 10 Best Offline Games For IOS You Cant Miss 2023

Good offline games for iOS are currently being searched by many young people. Because you don't need a 3/4G network, it's very convenient, you can play entertainment anytime, anywhere.

Top 10 Most Favorite Driving Simulator Games by Young People

Top 10 Most Favorite Driving Simulator Games by Young People

Driving simulation game is very popular with young people because it brings many strong feelings. So what are the best and most attractive driving games today?

Top 10 Super Attractive Google Games You Shouldnt Miss

Top 10 Super Attractive Google Games You Shouldnt Miss

Online gaming is becoming more and more popular. Pocket top 10 games on Google super attractive, interesting to experience gradually.

Top 10 Best and Most Attractive PC City Building Games

Top 10 Best and Most Attractive PC City Building Games

Are you looking for the hottest PC city building games today? Top games for those who love building and operating the city.