Uso de Tiles en Struts

Os mostramos como utilizar el sistema de plantillas proporcionado por Struts (tiles)

Uso de plantillas (tiles) en Struts

Cuando construimos un Web, podemos considerar que éste está formado
por una o varias plantillas en la que únicamente cada página cambia una porción
(normalmente central) del
contenido mostrado respecto a las restantes. La plantilla normalmente contiene un menú, publicidad,
cabeceras, pies, etc.

Si os fijáis  con detenimiento, nuestro Web
www.adictosaltrabajo.com está construido así (aunque
la tecnología es PHP básico). De este modo, para hacer crecer el Web solo necesitamos ir
añadiendo nuevas porciones. Además, cambiar todo el L&F sería relativamente rápido
(si alguno os animáis a colaborar, ya sabéis donde contactar).

Cuando utilizamos editores gráficos avanzados éstos nos permiten construir Webs con
esta filosofía. Si posteriormente se quiere sustituir una porción del site (por ejemplo
la cabecera) solo se toca en un sitio y el cambio se extiende a todo el sistema.
El único problema puede ser que con esta filosofía los creativos pueden
construir y mantener de un modo sencillo ramas estáticas de un Web pero en ramas
dinámicas necesitamos reproducir este comportamiento a través de código.

Hoy vamos a ver como se puede hacer esto con uno de los FrameWorks más
extendidos en Java (Struts)
y utilizando nuestro entorno de desarrollo habitual (NetBeans). Si aprendemos como lo hace este FrameWork podremos tener
criterios comparativos cuando diseñemos en nuestro o tengamos que decidir que
parte utilizamos y cual ignoramos o reemplazamos.

Definición de la plantilla

La construcción de páginas en base a plantillas se basa en la construcción de
tres elementos:

  • La plantilla que define elementos estáticos y áreas donde insertar otros
    contenidos
  • La página real que utiliza la plantilla insertando textos y otras
    porciones dinámicamente.
  • Las porciones particulares reutilizables (que pueden ser otros JSPs)

En un editor gráfico podemos construir nuestra plantilla
basándonos en tablas (con bordes ocultos). A mi me gusta MS FrontPage (como un
comienzo) porque es
muy intuitivo. Los diseñadores gráficos suelen preferir herramientas más
evolucionadas del tipo DreamWeaver.

Lo que realmente interesa es el HTML (en esta etapa). Hemos marcado en rojo los huecos
donde debemos insertar el código particular.

<html>

<head>
<title>Adictosaltrabajo.com</title>
</head>

<body>

<div align="center">
<center>
<table border="1" cellpadding="2" style="border-collapse: 
collapse; border-width: 0" bordercolor="#111111" id="AutoNumber1" width="756">
<tr>
<td width="773" style="border-style: none; border-width: medium" colspan="3">
    <a href="https://adictosaltrabajo.com/">
    <img src="https://adictosaltrabajo.com/imagenes/adic000.jpg" border="0" width="571" height="77"></a>
</td>
</tr>
<tr>
	<td width="140" style="border-style: none; border-width: medium">textolegal</td>
	<td width="508" style="border-style: none; border-width: medium">Mensajes</td>
	<td width="117" style="border-style: none; border-width: medium">login</td>
</tr>
<tr>
	<td width="140" style="border-style: none; border-width: medium">menu</td>
	<td width="508" style="border-style: none; border-width: medium">cuerpo</td>
	<td width="117" style="border-style: none; border-width: medium">otros</td>
</tr>
</table>
</center>
</div>
</body>
</html>

Creamos un  JSP que será la  plantilla en la aplicación Struts.
La generación de este JSP la podemos hacer a mano en nuestro proyecto o a través de los asistentes
gráficos (os lo recomiendo en un principio).

Le asignamos un nombre (no le pongáis la extensión JSP ya que se pone sola)

Una utilidad muy sencilla que podemos utilizar es el reformateo automático de
código (pulsando el botón derecho)

Podemos ahora añadir el código particular de Struts para tener acceso a la
funcionalidad de plantillas

<%@ taglib uri=»/tags/struts-tiles» prefix=»tiles» %>

Sin saber demasiado podemos ir escribiendo y NetBeans nos ayuda
autocompletando el código.

La plantilla

Nuestra plantilla quedará tal que así:

<%@page contentType="text/html"%>
<%@ taglib uri="/tags/struts-tiles" prefix="tiles" %>

<html>
<head><title><tiles:getAsString name="titulo" /></title></head>
<body>

<div align="center">
<center>
<table border="1" cellpadding="2" style="border-collapse: 
collapse; border-width: 0" bordercolor="#111111" id="AutoNumber1" width="800">
<tr>
<td width="773" style="border-style: none; border-width: medium" colspan="3">
    <a href="https://adictosaltrabajo.com/">
    <img src="https://adictosaltrabajo.com/imagenes/adic000.jpg" border="0" width="571" height="77">
</a></td>
</tr>
<tr>
<td width="140" style="border-style: none; border-width: medium">
<tiles:insert attribute="textolegal"/>
</td>
<td width="508" style="border-style: none; border-width: medium">
Mensajes
</td>
<td width="117" style="border-style: none; border-width: medium">
login
</td>
</tr>
<tr>
<td width="140" style="border-style: none; border-width: medium">
menu
</td>
<td width="508" style="border-style: none; border-width: medium">
<tiles:insert attribute="cuerpo"/>
</td>
<td width="117" style="border-style: none; border-width: medium">
otros
</td>
</tr>
</table>
</center>
</div>

</body>
</html>  

Es fácil predecir que con la etiqueta <tiles:insert attribute=»cuerpo«/>
estamos diciendo al sistema que en ese lugar se va a insertar un bloque
de HTML y/o JSP.

También podemos indicar que lo que insertaremos será un texto directamente <tiles:getAsString name=»titulo« />

La página

Nuestra página  especificará la plantilla a utilizar y
como rellenar cada apartado de la plantilla.

Ahora podemos completar nuestra página real.

Estamos indicando que en la plantilla el título se rellene con
en texto «Home del Web con Tiles»
y que la sección cuerpo se rellene con el JSP
/tiles/hometile.jsp

<%@page contentType="text/html"%>

<%@ taglib uri="/tags/struts-tiles" prefix="tiles" %>

<tiles:insert page="/plantilla.jsp" flush="true" >
	<tiles:put name="titulo" value="Home del Web con Tiles" />
	<tiles:put name="cuerpo" value="/tiles/hometile.jsp" />
</tiles:insert>

Creamos una carpeta donde metemos el JSP con el detalle (en
cuerpo de la página)

El cuerpo

Y creamos el JSP con dicho detalle

  <table border="1" cellpadding="2" style="border-collapse: collapse" 
bordercolor="#111111" width="100%" id="AutoNumber2">
<tr>
<td width="100%"><i><b><font size="6" color="#0000FF">Home</font></b></i><p>
	Aquí va a ir el cuerpo de la nueva home
</td>
</tr>
</table>  

Ya tenemos la página operativa y con nuestro gestor de plantillas.

Opciones para rellenar el campo título

En una aplicación normal, es muy posible que, dependiendo del cuerpo de una
página, nos interesase cambiar el título de una plantilla. Vamos a ver como
podemos hacer esto.

Asignar un valor directamente con scriptlet

<%@page contentType="text/html"%>
<%@taglib uri="/tags/struts-bean" prefix="bean" %>
<%@ taglib uri="/tags/struts-tiles" prefix="tiles" %>

<bean:define id="titulo" value="Home del Web con Tiles y propiedades" 
type="String" toScope="request" />

<tiles:insert page="/plantilla.jsp" flush="true" >
	<tiles:put name="titulo" value="<%= titulo %>" />
	<tiles:put name="cuerpo" value="/tiles/hometile.jsp" />
	<tiles:put name="textolegal" type="String">
	Soy el Texto Legal
</tiles:put>
</tiles:insert> 

Utilizar EL (Lenguaje de Expresiones)

  <%@page contentType="text/html"%>
<%@taglib uri="/tags/struts-bean" prefix="bean" %>
<%@ taglib uri="/tags/struts-tiles" prefix="tiles" %>
<%@page isELIgnored="false"%>

<bean:define id="titulo" value="Home del Web con Tiles y EL"
 type="String" toScope="request" />

<tiles:insert page="/plantilla.jsp" flush="true" >
	<tiles:put name="titulo" value="${titulo}"/>
	<tiles:put name="cuerpo" value="/tiles/hometile.jsp" />
	<tiles:put name="textolegal" type="String">
		Soy el Texto Legal
	</tiles:put>
</tiles:insert>    

Utilizar la etiqueta beanName

<%@page contentType="text/html"%>
<%@taglib uri="/tags/struts-bean" prefix="bean" %>
<%@ taglib uri="/tags/struts-tiles" prefix="tiles" %>

<bean:define id="titulo" value="Home del Web con Tiles y beanName" 
type="String" toScope="request" />

<tiles:insert page="/plantilla.jsp" flush="true" >
	<tiles:put name="titulo" beanName="titulo" />
	<tiles:put name="cuerpo" value="/tiles/hometile.jsp" />
	<tiles:put name="textolegal" type="String">
		Soy el Texto Legal
	</tiles:put>
</tiles:insert>   

Utilizar la etiqueta struts <bean:write>

<%@page contentType="text/html"%>
<%@page pageEncoding="UTF-8"%>
<%@taglib uri="/tags/struts-bean" prefix="bean" %>

<%@ taglib uri="/tags/struts-tiles" prefix="tiles" %>

<bean:define id="titulo" value="Home del Web con Tiles y write" 
type="String" toScope="request" />
<tiles:insert page="/plantilla.jsp" flush="true" >
	<tiles:put name="titulo">
		<bean:write name="titulo" />
	</tiles:put>
	<tiles:put name="cuerpo" value="/tiles/hometile.jsp" />
	<tiles:put name="textolegal" type="String">
		Soy el Texto Legal
	</tiles:put>
</tiles:insert>   

Utilización de etiqueta con cuerpo de tipo cadena de caracteres

 <%@page contentType="text/html"%>
<%@taglib uri="/tags/struts-bean" prefix="bean" %>
<%@ taglib uri="/tags/struts-tiles" prefix="tiles" %>

<bean:define id="titulo" value="Home del Web con Tiles y JSP Simple" 
type="String" toScope="request" />


<tiles:insert page="/plantilla.jsp" flush="true" >
	<tiles:put name="titulo" type="string">
		<%= titulo %>
	</tiles:put>
	<tiles:put name="cuerpo" value="/tiles/hometile.jsp" />
	<tiles:put name="textolegal" type="String">
		Soy el Texto Legal
	</tiles:put>
</tiles:insert>

Conclusiones

Struts es un FrameWork básico que nos permite empezar a unificar criterios en
el desarrollo de proyectos Java y solucionar las mismas situaciones de un modo
homogéneo (aunque no estemos demasiado convencidos de su perfección).

Una de las cosas que menos me gustan (en contra de lo que pudiera parecer) de la tecnología JSP es que lo mismo se
puede hacer de demasiados modos (y no hemos visto más que unos pocos). Esto aparentemente puede ser una ventaja pero
cuando tienes un equipo muy grande de gente manteniendo aplicaciones, creedme
que es un inconveniente.

Lanzo una pregunta al aire (que puede perturbar a departamentos de
arquitectura de grandes organizaciones):

¿Creéis que es conveniente unificar todos los
desarrollos en mi organización con un único FrameWork?

Mi opinión general es que NO
(aunque esto dependerá del contexto) …..

…. y posiblemente necesite DOS.

Comentarios

Deja una respuesta

Tu dirección de correo electrónico no será publicada. Los campos obligatorios están marcados con *

He leído y acepto la política de privacidad

Información básica acerca de la protección de datos

  • Responsable: IZERTIS S.A.
  • Finalidad: Envío información de carácter administrativa, técnica, organizativa y/o comercial sobre los productos y servicios sobre los que se nos consulta.
  • Legitimación: Consentimiento del interesado
  • Destinatarios: Otras empresas del Grupo IZERTIS. Encargados del tratamiento.
  • Derechos: Acceso, rectificación, supresión, cancelación, limitación y portabilidad de los datos.
  • Más información: Puedes ampliar información acerca de la protección de datos en el siguiente enlace:política de privacidad

Creador y propietario de AdictosAlTrabajo.com, Director General de Autentia S.L., Profesor asociado en IE Business School, inversor en StartUps y mentor de emprendedores. Ingeniero Técnico de Telecomunicaciones y Executive MBA por IE Business School 2007. Twitter: Follow @rcanalesmora Autor de los Libros: Planifica tu éxito: de aprendiz a empresario, Informática profesional, las reglas no escritas para triunfar en la empresa, Conceptos ágiles aplicados a distintas áreas de una empresa y Conversaciones con CEOs y CIOs sobre Transformación Digital y Metodologías Ágiles. ¡Descárgalos gratis aquí! Puedes consultar mi CV y alguna de mis primeras aplicaciones (de los 90) aquí.

¿Quieres publicar en Adictos al trabajo?

Te puede interesar

02/03/2026

José Antonio Sánchez Segovia

Zephyr es un RTOS open source respaldado por la Linux Foundation que permite desarrollar dispositivos embebidos conectados, eficientes y escalables, facilitando el paso de prototipo a producto final con una arquitectura mantenible.

23/02/2026

Enrique Casado Díez

LoRa y LoRaWAN son tecnologías clave en el ecosistema IoT cuando se requiere largo alcance y bajo consumo energético. En este artículo analizamos su funcionamiento, Spreading Factor, link budget, arquitectura de red, frecuencias y clases de dispositivos, con un caso práctico real.

19/02/2026

Juan José Díaz Antuña

Copilot Chat es la forma más sencilla y segura de empezar a usar IA en Microsoft 365. En este artículo vemos cómo funciona, cómo activarlo y en qué se diferencia de Microsoft 365 Copilot, Copilot Studio y los Agentes Inteligentes, con ejemplos prácticos y una comparativa clara.