data:image/s3,"s3://crabby-images/d0539/d05392d156d9b170034f76b49523a04e60b74a9f" alt="..."
Ng-grid is 100% angular grid which has no dependencies other than angular js. It has pagination, sorting, filtering and local data model binding/editing built in allowing for quick and easy integration with any Angular JS application.
In this post we will demonstrate few ng-grid features by using REST API over HTTP.
To get started we have add below references:
1. Angular JS
2. JQuery
3. Ng-Grid JS and CSS files
Steps to get data from REST API over HTTP and data binding to ng-grid
HTML
data:image/s3,"s3://crabby-images/3e4df/3e4dff41bbb84d07a33f6a25c5b21cae599d3c50" alt=""
JS
1. Declare your app module and add ng-grid
data:image/s3,"s3://crabby-images/72c27/72c27a857f39dc9880b345636cba39138a358906" alt=""
2. Assign controller to your app module
data:image/s3,"s3://crabby-images/32a0d/32a0d95eede3dde21101da8607e8186cff737b59" alt=""
3. Script that returns JSON object from API using HTTP. Here am querying SharePoint list “EmployeeDetails” and retrieving values from 4 columns EmployeeID, EmployeeName, Department, ProfilePic.
data:image/s3,"s3://crabby-images/f1eea/f1eea3fea0c82fb1312bf953c3b2ad6da0c9665f" alt=""
4. Now initialize grid options under same controller as data. This binds the data to grid.
data:image/s3,"s3://crabby-images/f7e6d/f7e6d4811d89189aa5f9e759fc61d51236e13a19" alt=""
5. To bind only specific columns, we can define column definitions in ng-grid as below. It is common requirement for any Grid to have column names (display name) different from JSON name. Let’s bind only 4 columns which are retrieved from list.
data:image/s3,"s3://crabby-images/0bedf/0bedf3fdaa1a7a5634210b75332f0358cbb5fd30" alt=""
OUTPUT
data:image/s3,"s3://crabby-images/c5d2d/c5d2dbb74bfae743fea028c7591def2f969deb37" alt=""
Pagination
When pagination is enabled, data is displayed in pages that can be browsed using built in pagination selector. Lets build simple pagination.
To define page size and index,
data:image/s3,"s3://crabby-images/f9a90/f9a90c077d8496425094292547f1b6632ba4cc71" alt=""
data:image/s3,"s3://crabby-images/c501e/c501ee330293f3198b071c8af1c30ca4b829e7a3" alt=""
To bind data when page is changed, we have to make http call in PagedDataAsync method,
data:image/s3,"s3://crabby-images/fd4d3/fd4d3176070317bd35053524d47f1d7af892eabb" alt=""
Finally while binding data, we have to enable pagination
data:image/s3,"s3://crabby-images/042ed/042ed44aa11f9bc22fb226e85cec3f67d80b68df" alt=""
OUTPUT
data:image/s3,"s3://crabby-images/dd7a3/dd7a325466d8fea023792780dc7ed4f281530da9" alt=""
Sorting
Sorting is ‘ON’ by default. You can set enableSorting flag in gridOptions to enable/disable it.
Sorting can also be disabled at column level by setting enableSorting : false in column definition
data:image/s3,"s3://crabby-images/ff45b/ff45b068eeba68c04d5db016ab5e3507f210921b" alt=""
OUTPUT
Sorted by EmployeeName
data:image/s3,"s3://crabby-images/8c804/8c804bd05643706d31285af1fa3d85cce69ea4a9" alt=""
data:image/s3,"s3://crabby-images/37c56/37c56d92eb174793980b4bf5a3bbb5645f09b24a" alt=""