In Facelets 1.x è possibile creare un file di tag per questo scopo.
Ecco un esempio di kickoff di base. Creare /WEB-INF/tags/some.xhtml
:
<ui:composition
xmlns:f="http://java.sun.com/jsf/core"
xmlns:h="http://java.sun.com/jsf/html"
xmlns:ui="http://java.sun.com/jsf/facelets"
>
<h:outputText value="#{foo}" />
</ui:composition>
definirlo in /WEB-INF/my.taglib.xml
:
<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE facelet-taglib PUBLIC
"-//Sun Microsystems, Inc.//DTD Facelet Taglib 1.0//EN"
"http://java.sun.com/dtd/facelet-taglib_1_0.dtd">
<facelet-taglib>
<namespace>http://example.com/jsf/facelets</namespace>
<tag>
<tag-name>some</tag-name>
<source>/WEB-INF/tags/some.xhtml</source>
</tag>
</facelet-taglib>
registrarlo in /WEB-INF/web.xml
:
<context-param>
<param-name>facelets.LIBRARIES</param-name>
<param-value>/WEB-INF/my.taglib.xml</param-value>
</context-param>
(nota, quando si dispone di più, utilizzare il punto e virgola ;
per separarli)
Infine, basta dichiararlo nei modelli della pagina principale.
<ui:composition
xmlns:f="http://java.sun.com/jsf/core"
xmlns:h="http://java.sun.com/jsf/html"
xmlns:ui="http://java.sun.com/jsf/facelets"
xmlns:my="http://example.com/jsf/facelets"
>
<my:some foo="value1" />
<my:some foo="value2" />
<my:some foo="value3" />
</ui:composition>
Un esempio più avanzato può essere trovato qui: How to make a grid of JSF composite component? Nota: JSF 2.0 di mira, ma con piccole modifiche sulla base di esempio precedente funziona come bene su Facelets 1.x.
Stai usando JSF 2.0? –
Mi dispiace, ho dimenticato di aggiungere questo al sommario. Io uso 1.2 – Daggeto