JSF Portlet Backing Beans and UI Components Copyright © Liferay, Inc. All Rights Reserved. No material may be reproduced electronically or in print without written permission from Liferay, Inc.
Objective 1.Add JSF UI Components –index.jsp 2.Register & create the Backing Bean with JSF –faces-config.xml 3.Bind Backing Bean Property to UI Component –index.jsp
Key Concepts UI Component –A Stateful object, maintained on the server, that provides functionality for interacting with an end user. –UI components are JavaBeans with properties, methods, and events. –Organized into a view, which is a tree of components usually displayed as a page. Backing Bean –Specialized JavaBeans that collect values from UI components and implement event listener methods.
Add JSF UI Components Modify …/ext/portlets/library_jsf.war/index.jsp and add some UI components.
index.jsp
Deploy the Files to Tomcat Open up a cmd prompt –Click “Start”, “Run” and then type “cmd” Navigate to your ext\portlets directory and then type “ant compile deploy” …\ext\portlets>ant compile deploy From your browser, Click Home A1 or use CTRL-F5 to reload the portlet
Register your Backing Bean with JSF Create …/ext/portlets/library_jsf_portlet.war/WEB- INF/faces-config.xml. This file is used to store all of your JSF configuration information:
faces-config.xml book com.ext.portlet.library.ui.BookBean request
Create your Backing Bean In …/ext/portlets/library_jsf_portlet.war/WEB- INF/src, use Eclipse to create com.ext.portlet.library.ui.BookBean:
BookBean.java package com.ext.portlet.library.ui; import java.util.ArrayList; import java.util.List; import javax.faces.application.FacesMessage; import javax.faces.context.FacesContext; import javax.faces.event.ActionEvent; public class BookBean { public String getTitle() { return _title; } public void setTitle(String title) { _title = title; } private String _title; }
Initialize Values Modify faces-config.xml. This will initialize BookBean.title every time it is created (per request):
faces-config.xml book com.ext.portlet.library.ui.BookBean request title <book name>
Bind Backing Bean Property to UI Component Modify index.jsp. Adding value=“#{book.title}” binds the title property of the book bean to this input field.
index.jsp
Deploy the Files to Tomcat Open up a cmd prompt –Click “Start”, “Run” and then type “cmd” Navigate to your ext\portlets directory and then type “ant compile deploy” …\ext\portlets>ant compile deploy From your browser, Click Home A1 or use CTRL-F5 to reload the portlet
Create Command Button Modify index.jsp and add a command button. We will be using this button in a later exercise to add books to the database:
index.jsp
Register Simple Action Listener Modify index.jsp. Bind the BookBean.addBook() to the command button’s actionListener. When the form is submitted JSF will generate an action event that will invoke this actionListener:
index.jsp
Handle Action Event Modify BookBean.java. Add the addBook() to handle the action event generated by the commandButton. The event handler will clear the title field when it is invoked:
BookBean.java package com.ext.portlet.library.ui; import java.util.ArrayList; import java.util.List; import javax.faces.application.FacesMessage; import javax.faces.context.FacesContext; import javax.faces.event.ActionEvent; public class BookBean { public String getTitle() { return _title; } public void setTitle(String title) { _title = title; } public void addBook(ActionEvent actionEvent) { // clear the title setTitle(""); } private String _title; }
Deploy the Files to Tomcat Compile and redeploy, restart Tomcat and refresh browser. Verify that the input field is being cleared after you submit the form.
Revision History James Min01/17/2007 Ivan Cheung01/30/2007