JSF - Edit Data of a DataTable


In this article, we'll showcase adding editing capability to a row in datatable

Example Application

Let us create a test JSF application to test the above functionality.

1Create a project with a name helloworld under a package com.tutorialspoint.test as explained in the JSF - Display DataTable sub-chapter of JSF - Data Tables chapter.
2Modify home.xhtml as explained below. Keep rest of the files unchanged.
3Compile and run the application to make sure business logic is working as per the requirements.
4Finally, build the application in the form of war file and deploy it in Apache Tomcat Webserver.
5Launch your web application using appropriate URL as explained below in the last step.


<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" 
<html xmlns="http://www.w3.org/1999/xhtml"   
      <title>JSF tutorial</title>		
      <h:outputStylesheet library="css" name="styles.css"  /> 	
   <h2>DataTable Example</h2>
      <h:dataTable value="#{userData.employees}" var="employee"
            <f:facet name="header">Name</f:facet>    				
            <h:inputText value="#{employee.name}"
               size="10" rendered="#{employee.canEdit}" />
            <h:outputText value="#{employee.name}"
               rendered="#{not employee.canEdit}" />
            <f:facet name="header">Department</f:facet>
            <h:inputText value="#{employee.department}" 
               size="20" rendered="#{employee.canEdit}" />
            <h:outputText value="#{employee.department}" 
               rendered="#{not employee.canEdit}" />
            <f:facet name="header">Age</f:facet>
            <h:inputText value="#{employee.age}" size="5"
               rendered="#{employee.canEdit}" />
            <h:outputText value="#{employee.age}" 
               rendered="#{not employee.canEdit}" />
            <f:facet name="header">Salary</f:facet>
            <h:inputText value="#{employee.salary}" 
               size="5" rendered="#{employee.canEdit}" />
            <h:outputText value="#{employee.salary}" 
               rendered="#{not employee.canEdit}" />
            <f:facet name="header">Edit</f:facet>
               <h:commandButton value="Edit" 
                  rendered="#{not employee.canEdit}">        
                     target="#{userData.employee}" value="#{employee}" />
	<h:commandButton value="Save Employees"
          action="#{userData.saveEmployees}" />	  

Once you are ready with all the changes done, let us compile and run the application as we did in JSF - First Application chapter. If everything is fine with your application, this will produce following result:

JSF Edit Data of datatable

Click edit button of any row.See the result. JSF Edit Data of datatable1

Click Save Employees button to save the edit.See the result. JSF Edit Data of datatable2