14. Versión 9: Implementación de la capa web con Primefaces
Requisitos previos: se leerá «Introducción a Primefaces» en [ref3].
Pregunta 1: crear un nuevo proyecto Maven de tipo [Web Application] en el que las páginas XHTML del ejemplo anterior se construyan con componentes de Primefaces. No se modificarán los beans.
La página de inicio utiliza los componentes <p:panel>, <p:inputText>, <p:selectOneMenu> y <p:message>:
![]() |
Una entrada errónea:
![]() |
Una simulación:
![]() |
La lista de simulaciones utiliza los componentes <p:dataTable>, <p:commandLink>:
![]() |
Los métodos AJAX actualizarán el área con id='formulario' que incluye toda la página (véase la línea 11 más abajo):
<?xml version='1.0' encoding='UTF-8' ?>
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html xmlns="http://www.w3.org/1999/xhtml"
xmlns:h="http://java.sun.com/jsf/html"
xmlns:f="http://java.sun.com/jsf/core"
xmlns:ui="http://java.sun.com/jsf/facelets">
<f:view locale="#{sessionData.locale}">
...
<h:body style="background-image: url('${request.contextPath}/resources/images/standard.jpg');">
<h:form id="formulaire">
<!-- encabezado -->
<ui:include src="entete.xhtml" />
<!-- contenido -->
<ui:insert name="part1" >
Gestion des assistantes maternelles
</ui:insert>
<ui:insert name="part2"/>
</h:form>
</h:body>
</f:view>
</html>
Una vez que su aplicación funcione, sustituya la página [entete.xhtml] por la siguiente:
<?xml version='1.0' encoding='UTF-8' ?>
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html xmlns="http://www.w3.org/1999/xhtml"
xmlns:h="http://java.sun.com/jsf/html"
xmlns:p="http://primefaces.org/ui"
xmlns:f="http://java.sun.com/jsf/core"
xmlns:ui="http://java.sun.com/jsf/facelets">
<!-- encabezado -->
<h:panelGroup>
<h2><h:outputText value="#{msg['form.titre']}"/></h2>
</h:panelGroup>
<p:menubar id="menu" header="Menu" style="width: 500px">
<p:submenu label="#{msg['form.menu.simulation']}">
<p:menuitem id="cmdFaireSimulation" style="width: 200px" value="#{msg['form.menu.faireSimulation']}" actionListener="#{form.faireSimulation}" rendered="#{sessionData.menu.faireSimulation}" update=":formulaire:contenu"/>
<p:menuitem id="cmdEffacerSimulation" style="width: 200px" onclick="raz();" immediate="true" value="#{msg['form.menu.effacerSimulation']}" actionListener="#{form.effacerSimulation}" rendered="#{sessionData.menu.effacerSimulation}" update=":formulaire:contenu"/>
<p:menuitem id="cmdEnregistrerSimulation" style="width: 200px" immediate="true" value="#{msg['form.menu.enregistrerSimulation']}" actionListener="#{form.enregistrerSimulation}" rendered="#{sessionData.menu.enregistrerSimulation}" update=":formulaire:contenu"/>
</p:submenu>
<p:submenu label="Navigation">
<p:menuitem id="cmdRetourSimulateur" style="width: 200px" immediate="true" value="#{msg['form.menu.retourSimulateur']}" actionListener="#{form.retourSimulateur}" rendered="#{sessionData.menu.retourSimulateur}" update=":formulaire:contenu"/>
<p:menuitem id="cmdVoirSimulations" style="width: 200px" immediate="true" value="#{msg['form.menu.voirSimulations']}" actionListener="#{form.voirSimulations}" rendered="#{sessionData.menu.voirSimulations}" update=":formulaire:contenu"/>
</p:submenu>
<p:menuitem id="cmdTerminerSession" immediate="true" value="#{msg['form.menu.terminerSession']}" actionListener="#{form.terminerSession}" rendered="#{sessionData.menu.terminerSession}" update=":formulaire:contenu"/>
</p:menubar>
<p:spacer height="50px"/>
</html>
- línea 15: una barra de menú de Primefaces,
- línea 16: una opción de menú en dicha barra,
- línea 17: un elemento de esta opción de menú.
La plantilla no se ve afectada por este cambio. La nueva vista es la siguiente:




