Skip to main content

Data-tables over traditional HTML tables

This blog post is about using datatables v0.5 (http://l-lin.github.io/angular-datatables/archives/) with Angular 1. We can easily feed data using angular into a datatable from https://datatables.net/ which is built using jQuery.




Why data-tables ?

There are many benefits of using data-tables. 

  • One major benefit is if you are not a UI/UX person, and don't want to spend much time styling, you can still give users a good experience by just including a data table.
  • You will not have to put effot into implementing search or sort. It is by default provided. 


Pre-requisites

In order to use datatables you will need the following dependencies to be added to your project.

jQuery
datatables.net
datatables.net-dt
angular-datatables

You can use npm, bower or the cdns to include these in your project.

When using the bower component for angular-datatables I encountered a problem since the datatables we are using is an old version. To get over that, I have used the CDN for angular-datatables.

After adding the dependencies, they should be linked to the index.html as follows.

 <script src="./bower_components/jQuery/dist/jquery.min.js"></script>  
 <script src="./bower_components/datatables.net/js/jquery.dataTables.min.js"></script>  
 <script src="./bower_components/angular/angular.js"></script>=  
 <script src="https://cdnjs.cloudflare.com/ajax/libs/angular-datatables/0.5.6/angular-datatables.js"></script>  
 <link rel="stylesheet" href="https://cdnjs.cloudflare.com/ajax/libs/angular-datatables/0.5.6/css/angular-datatables.css">  

Be mindful to follow the order as above.


Angular module

When registering the angular module, datatables dependency should be injected as below.

 var myApp = angular.module('inward', [  
   'datatables'  
 ]);  

Angular Controller

Following is the code for the controller.

 myApp.controller('DataCtrl', getData);  
 function getData() {  
   var vm = this;  
   var persons = [{  
     "id": 860,  
     "firstName": "Mary",  
     "lastName": "Jane"  
   }, {  
     "id": 870,  
     "firstName": "Tony",  
     "lastName": "Stark"  
   }, {  
     "id": 590,  
     "firstName": "Darth",  
     "lastName": "Wader"  
   }, {  
     "id": 803,  
     "firstName": "Bruce",  
     "lastName": "Wayne"  
   }, {  
     "id": 857,  
     "firstName": "Matthew",  
     "lastName": "Murdock"  
   }];  
   vm.persons = persons;  
 }  

Persons array is what we will be feeding to the data table.


HTML view

Now the above controller will be bound to the view as follows.

 <div class="col-xs-12">  
   <div class="card">  
     <div class="card-body" ng-controller="DataCtrl as showCase">  
       <!--<button type="button" class="btn btn-primary">Add new ward</button>-->  
       <table datatable="ng" class="datatable table table-striped primary dataTable no-footer" cellspacing="0" width="100%" id="DataTables_Table_0" role="grid" aria-describedby="DataTables_Table_0_info" style="width: 100%;">  
         <thead>  
         <tr role="row">  
           <th tabindex="0" aria-controls="DataTables_Table_0" rowspan="1" colspan="1" style="width: 142px;">ID</th>  
           <th tabindex="0" aria-controls="DataTables_Table_0" rowspan="1" colspan="1" style="width: 223px;">First Name</th>  
           <th tabindex="0" aria-controls="DataTables_Table_0" rowspan="1" colspan="1" style="width: 105px;">Last Name</th>  
         </thead>  
         <tbody>  
         <tr role="row" ng-repeat="person in showCase.persons">  
           <td>{{ person.id }}</td>  
           <td>{{ person.firstName }}</td>  
           <td>{{ person.lastName }}</td>  
         </tr>  
         </tbody>  
       </table>  
     </div>  
   </div>  
 </div>  

Finally, the data table will be shown in the view. It will automatically search and sort without requiring any code to be written.




Comments

Popular posts from this blog

Admin panel of a Q & A Forum

In a Q & A Forum, when a user posts a question, it should be sent to the administrator for approval in case it contains inappropriate content. After approval it should be removed from this pending approval page and other users should be able to see the question afterwards. To enable this, we should maintain an approval column in our database table of records and for each record approval should be set to false by default. In the Pending approvals page only the records with approval=false should be displayed. Below is  the MySQL  statement for retrieval, $sql="SELECT * FROM topics WHERE approval=false"; To know which post was approved we should embed the post_id to the URL. And the relevant post should be updated as approval=true. Below is the complete code. <?php $sql="SELECT * FROM topics WHERE approval=false"; $query=mysqli_query($conn,$sql); echo '<form name="approve" method="p...

Calculator using PHP

This Calculator model will take inputs from the Number 1 and Number 2 fields and when the user clicks on the relevant operator the result will be displayed in the Results field. For log10(), to radian, to degree, sin, cos, tan operations only require one input. Hence, the user is instructed to input the values to the 1st field only. First, before proceeding with the calculation, we need to obtain the values from the text boxes. For that we should include all the form elements inside a form. The result is directed to the same page. Therefore we will use the form action as $_SERVER['PHP_SELF'] and the method as post. Next, we can obtain the values in the text boxes.       $_POST[' form_element_name '] will give you the value of the respective element. We can write the php code as follows (in the <head>) to obtain the value from Number 1 and Number 2 fields.       <?php              $num1=...

Fixing 'java RMI - ConnectException: Operation timed out' in WSO2 Enterprise Integrator 6.4

If you ever come across the below exception when running WSO2 Enterprise Integrator 6.4, here is the fix. This error occurs when you have multiple IP addresses from different networks configured in your etc/hosts as below. 10.xxx.x.xxx localhost 192.xxx.x.xxx localhost So simply, removing the unnecessary one and leaving the one of the network that you are currently connected to should resolve this issue. 10.xxx.x.xxx localhost