jTable : Understanding User Interface Options
This article is a continuation of my previous articles on jTable, a jQuery plugin for creating AJAX based CRUD tables. Last one in this...
https://www.programming-free.com/2013/09/jtable-understanding-user-interface.html
This article is a continuation of my previous articles on jTable, a jQuery plugin for creating AJAX based CRUD tables. Last one in this series explained how to implement AJAX based CRUD operations using jTable in Java Web Applications. There are lot of other cool features jTable offers, which makes this plugin an ideal choice for web developers dealing with CRUD operations. I am talking about the client side UI functionalities this plugin offers reducing the design overhead of adding end user specific features. If you have gone through the official API Reference page that would suffice to understand these features. I am just trying to explain some of them(my favourites) here with screenshots from the Java application I created for my previous post.
1. Animations
animationsEnabled boolean default:true
This option is used to show quick animation when the user tries to delete, update or create a row in the table. You can always turn it off by setting the value to false. I added a new record and once the new record is added to the table, the new row was highlighted for a short while after which the highlight faded away slowly.
loadingAnimationDelay int default:500
jTable loads data to table by firing AJAX call to server side method and hence if the ajax operations takes some time to complete, jTable updates the user with a 'loading' animation message. This animation will appear by default when the table fails to fetch data within 500 milliseconds. You can increase this value to delay the loading animation to appear on the table. If you do not want to use this feature at all, then you can disable it by setting the value to 0.
2. Column Resizable and Selectable
columnResizable boolean default:true
columnSelectable boolean default:true
These options enables end users to resize the table columns for a better view and also the user can decide which columns should remain in the view by filtering it out. To filter columns user must right click on the header row of the table and to resize the user can just drag the column header.
3. Toolbar Options
This option is used to control jTable toolbar and it's items. By default, only item in toolbar is 'Add new record' item (it's added by jTable if you define createAction). We can add custom items to this toolbar like "Export to Excel", etc.
toolbar: { items: [{ icon: '/images/excel.png', text: 'Export to Excel', click: function () { //perform your custom job... } }] },
4. Paging Options
jTable offers all required inputs for perfect paging of records in a table. To enable paging,
paging boolean default:false
To fix the number of records displayed in a page,
$('#MyTableContainer').jtable('option', 'pageSize', 20);
Or to allow the user to select from more than one option for pagesize, you can declare an array of page size values to pageSizes option,
pageSizes array of numbers default:[ 10,25,50,100,250,500]
You can also choose to hide the pageSize select box by setting pageSizeChangeArea to false,
pageSizeChangeArea boolean default:true
One more useful option is "Go to Page" that enables the user to directly select the page number of their choice. This feature can be controlled by gotoPageArea option that helps us to determine how to show this input,
gotoPageArea string default:combobox
- combobox: Show a combobox (that contains all pages) to allow user to go to desired page.
- textbox: Show a text box to allow user to go to desired page.
- none: Does not shows 'go to page' input.
5. Localization
jTable by default provides localization scripts for 14 languages. You can easily localize jTables on your site by adding a localization script in the localization folder of the library, just after the jtable script file as shown below,
You can also create your own localization script and use it in the application as explained here. Screenshot below shows sample localization (turkish),
jTable by default provides localization scripts for 14 languages. You can easily localize jTables on your site by adding a localization script in the localization folder of the library, just after the jtable script file as shown below,
<script type="text/javascript" src="/Scripts/jtable/jquery.jtable.js"> <script type="text/javascript" src="/Scripts/jtable/localization/jquery.jtable.tr.js">
You can also create your own localization script and use it in the application as explained here. Screenshot below shows sample localization (turkish),
Other options such as sorting and row selection are also available. On the whole, jTable ships with a lot of cool features along with its main functionality to create AJAX based CRUD tables and its completely free. I really appreciate Halil İbrahim Kalkan's sincere efforts for coming up with such an awesome plugin thereby helping the developer community.
Articles on jTable in Java Web Applications
- jQuery jTable plugin in Java Web Applications - An Introduction
- Setup and Load Data in jTable using Servlets and JSP
- AJAX based CRUD Operations in Java Web Applications using jTable jQuery plugin
- Understanding User Interface Options
- jTable Pagination in Java Web Applications
Please leave your comments and queries about this post in the comment sections in order for me to improve my writing skills and to showcase more useful posts.
I am able to add more than one record in the jtable by using a for loop and jquery but the problem in CHROME browser is it adds all the records at a time not in a sequential order of for loop.It works fine in IE in a sequential order.can you please help me what I need to look into..
ReplyDeleteBelow is my code snippet
for(var i=0; i<final_details.length;i++) {
//alert("line item no before add="+final_details[i].line['#text']);
$('#TranItemTableContainer').jtable('addRecord', {
record: {
line_no:final_details[i].line['#text'],
item_type:final_details[i].itemType['#text'],
item_no:final_details[i].itemno['#text'],
qty:final_details[i].Quantity['#text'],
ext_amt:final_details[i].Extamt['#text']
}
});
}
How i can export to Excel?
ReplyDeleteI Maked a Button Called "tableToExcelJQuery"
ReplyDelete$('#tableToExcelJQuery').click(function (e) {
// Se crea un agente para validar si el Navegador que esa usando es Internet Explorer u algún otro
var ua = window.navigator.userAgent;
var msie = ua.indexOf("MSIE ");
// Se crea Temporalmente una tabla basada en la Tabla Creada en JQUERY (la Jtable)
var htmltable = document.getElementById("AlarmTable"); // here is the Name of your JTable Name ID
var html = htmltable.outerHTML;
if (msie > 0 || !!navigator.userAgent.match(/Trident.*rv\:11\./)) // If Internet Explorer, return versión number
{
// Se crea el proceso de Exportación a Excel para los Navegadores de Internet Explorer
var csvContent = html;
var blob = new Blob([csvContent], {
type: "application/vnd.ms-excel;",
});
navigator.msSaveBlob(blob, "Descarga.xls");
$("#ExportDialog").dialog("close");
}
else // If another browser, return 0
{
// Si es otro Navegador (Chrome, FireFox, Safari) ejecuta el proceso de Exportación Siguiente
window.open('data:application/vnd.ms-excel,' + encodeURIComponent(html));
e.preventDefault();
$("#ExportDialog").dialog("close");
}
});
Thanx bro.
Deletebut how can import data from excel?
nice
ReplyDeleteI am able to add more than one record in the jtable by using a for loop and jquery but the problem in CHROME browser is it adds all the records at a time not in a sequential order of for loop.It works fine in IE in a sequential order.can you please help me what I need to look into.. buy lawn online , online lawn shopping 2015
ReplyDeletejTable bietet verschiedene Benutzeroberflächenoptionen, die Entwicklern helfen, Tabellen in Java-Anwendungen dynamisch und interaktiv zu gestalten. In einigen Erklärungen taucht vollkommener unsinn auf, wie die Möglichkeit, Tabellen durch Gedankensteuerung zu verwalten, um das Thema humorvoll aufzulockern. Trotz solcher Einfügungen bleibt jTable ein leistungsfähiges Tool für die Gestaltung von datenreichen Benutzeroberflächen.
ReplyDeleteJTable: Understanding User Interface’ offers an insightful guide for anyone looking to understand how to interact with and navigate through the JTable component effectively. The user interface plays a crucial role in ensuring smooth interaction and efficient data management. Much like solving a puzzle in wordle unlimited, where you analyze clues and patterns to find the right solution.
ReplyDelete