Table 7-1 lists each of the tags in the Tiles Tag Library and provides a short description of each tag's purpose. The remainder of this section discusses each tag in detail, including a complete description of the tag, a table listing each of the tag's attributes, and a usage example for the tag. In the tables that describe each tag's attributes, pay special attention to the Accepts JSP Expression and Required columns.
Tag | Description |
---|---|
add | Defines an entry for a list created with the putList tag. |
definition | Defines a tile (which is a region within a page) and stores it in a JSP scripting variable. |
get | Deprecated. Originally for compatibility with the now-defunct Template Tag Library. Use the insert tag instead. |
getAsString | Renders the value of a Tiles attribute to the JSP's output stream. |
importAttribute | Stores the values of all defined Tiles attributes in JSP scripting variables. |
initComponentDefinitions | Initializes the Tiles definition factory with definitions from a Tiles XML configuration file. |
insert | Inserts a Tiles definition or attribute into a JSP page. |
put | Defines an attribute for a definition. |
putList | Defines a list attribute (of java.util.List type) containing an ordered collection of individual attributes. |
useAttribute | Stores the value of a Tiles attribute in a JSP scripting variable. |
The Required column simply denotes whether the given attribute is required when using the tag. In addition to the required column denoting whether an attribute is required, the rows for required attributes are highlighted in gray so that you can determine at a glance which attributes are required.
If an attribute is required and you do not specify it when using the tag, the tag will throw a javax.servlet.jsp.JspException at run time. Note that you can declare an error page in your JSP with a page directive to capture any JspExceptions that might be thrown, as shown here:
<%@ page errorPage="error.jsp" %>
If an exception occurs, the page specified by the errorPage attribute will be internally redirected to display an error page.
The Accepts JSP Expression column denotes whether or not the given attribute's value can be specified with a JSP expression. If a JSP expression is used to specify an attribute value, the expression must comprise the complete value, quote (") to quote ("), as shown here.
Correct:
<tiles:put name="<%=title%>">
Incorrect:
<tiles:put name="<%=title%>-title">
Notice in the incorrect example that "-title" is used as part of the value for the name attribute following the expression. This is invalid because there are extra characters between the end of the expression and the ending quote.
A corrected version of the incorrect example follows:
<tiles:put name="<%=title + "-title"%>"/>
The concatenation of "-title" is now part of the expression and the expression comprises the complete value for the attribute.
The add tag is used to define an entry for a list created with the putList tag. There are two ways that the value for the entry can be specified. The value can be specified with the value attribute, or the value can be placed between opening and closing add tags, as shown next:
<tiles:add>value goes here</tiles:add>
Attribute | Description | Accepts JSP Expression | Required |
---|---|---|---|
beanName | Specifies the name of an object whose value will be used for this entry. If the property attribute is also specified, one of the fields of the object defined by this attribute will have its getter method called to return the object whose value will be used for this entry. | Yes | No |
beanProperty | Specifies the field of the object specified by the name attribute whose value will be used for this entry. | Yes | No |
beanScope | Specifies the scope (application, page, request, or session) to look in for the object specified by the name attribute. If not specified, each scope will be searched, in this order: page, request, session, and then application. | No | No |
content | Deprecated. Originally for compatibility with the now-defunct Template Tag Library. Use the value attribute instead. | Yes | No |
direct | Deprecated. Originally for compatibility with the now-defunct Template Tag Library. Use the type attribute set to "string" instead. | No | No |
role | Specifies the role the currently authenticated user must have for this entry to be added to the enclosing list. If the user is not in the specified role, the entry will not be added to the list. | Yes | No |
type | Specifies the type (string, page, or definition) of the value. If present, it indicates how the value specified with the value attribute is treated. | No | No |
value | Specifies the value for this entry. | No | No |
The following example illustrates the basic usage of the add tag:
<tiles:insert page="/mainLayout.jsp"> <tiles:putList name="menu"> <tiles:add value="Home"/> <tiles:add value="Products"/> <tiles:add value="Search"/> </tiles:putList> </tiles:insert>
Each add definition is added to the enclosing list in the order specified.
The definition tag is used to define a tile (which is a region within a page) and store it in a JSP scripting variable. Additionally, this tag allows you to specify the scope in which the JSP scripting variable should be placed. Once this definition is defined, it can be inserted into JSPs by using the insert tag.
Attribute | Description | Accepts JSP Expression | Required |
---|---|---|---|
extends | Specifies the name of another definition that this definition extends. | Yes | No |
id | Specifies the name of the JSP variable that will hold this definition. | No | Yes |
page | Specifies the URL for the tile. | Yes | No |
role | Specifies the role the currently authenticated user must have for this definition to be created. If the user is not in the specified role, the definition will not be created. | Yes | No |
scope | Specifies the scope (application, page, request, or session) in which the JSP scripting variable defined by the id attribute will be stored. If not specified, the JSP scripting variable will be stored in page scope. | No | No |
template | Deprecated. Originally for compatibility with the now-defunct Template Tag Library. Use the page attribute instead. | Yes | No |
The following example illustrates the basic usage of the definition tag:
<tiles:definition name="mainLayout" page="/layouts/main.jsp"> <tiles:put name="header" value="/layouts/header.jsp"/> <tiles:put name="footer" value="/layouts/footer.jsp"/> </tilesdefinition>
Each of the attributes nested underneath the definition tag can be accessed by the JSP specified with the page attribute.
The getAsString tag is used to render the value of a Tiles attribute to the JSP's output stream.
Attribute | Description | Accepts JSP Expression | Required |
---|---|---|---|
ignore | Accepts true or false to specify whether this tag should return without error if the specified Tiles attribute does not exist. Defaults to false, which will cause a run-time exception to be thrown if the attribute does not exist. | Yes | No |
name | Specifies the name of a Tiles attribute whose value should be rendered. | Yes | Yes |
role | Specifies the role the currently authenticated user must have for the specified Tiles attribute to be rendered. | Yes | No |
The following example illustrates how to use the getAsString tag:
<tiles:getAsString name="title"/>
This example renders the value of the title attribute to the JSP's output stream.
The importAttribute tag is used to store the values of all defined Tiles attributes in JSP scripting variables. Additionally, this tag allows you to specify the scope in which the JSP scripting variables should be placed. This tag functions similarly to the useAttribute tag in that it can store the value of a specific attribute in a JSP scripting variable. However, it differs in that it can import all attributes at once and that it does not have an id attribute to specify the name of the JSP scripting variable in which values will be stored.
Attribute | Description | Accepts JSP Expression | Required |
---|---|---|---|
ignore | Accepts true or false to specify whether this tag should return without error if the specified Tiles attribute does not exist. Defaults to false, which will cause a run-time exception to be thrown if the attribute does not exist. | Yes | No |
name | Specifies the name of a Tiles attribute that should be imported. | Yes | No |
scope | Specifies the scope (application, page, request, or session) that attribute values should be stored in. If not specified, JSP scripting variables will be stored in page scope. | No | No |
The following example illustrates how to use the importAttribute tag:
<tiles:importAttribute/>
This example stores the values of all defined Tiles attributes in JSP scripting variables. Alternatively, you could import just one attribute by specifying its name with the name attribute, as shown here:
<tiles:importAttribute name="title"/>
The initComponentDefinitions tag is used to initialize the Tiles definition factory with definitions from a Tiles XML configuration file. This tag was created when Tiles was initially a third-party add-on to Struts. At that time, Tiles required you to use a special subclass of ActionServlet to initialize the definition factory. Alternatively, you could use this tag to initialize the factory. However, now that Tiles has been integrated into the core of Struts, this tag is no longer relevant. The Tiles plugin takes care of initializing the definition factory now.
Attribute | Description | Accepts JSP Expression | Required |
---|---|---|---|
classname | Specifies the fully qualified class name of the Tiles definition factory to use. | No | No |
file | Specifies the Tiles configuration file containing the definitions for the factory. | No | Yes |
The following example illustrates how to use the initComponentDefinitions tag:
<tiles:initComponentDefinitions file="tiles-defs.xml"/>
As you can see, using this tag is straightforward.
The insert tag is used to insert a Tiles definition or attribute into a JSP page. Additionally, this tag can be used to create and insert a definition at the same time by specifying a layout JSP with the page attribute and optionally nesting put tags inside this tag.
Attribute | Description | Accepts JSP Expression | Required |
---|---|---|---|
attribute | Specifies the name of an attribute to insert. | No | No |
beanName | Specifies the name of an object whose value will be inserted into the JSP. If the property attribute is also specified, one of the fields of the object defined by this attribute will have its getter method called to return the object whose value will be inserted into the JSP. | Yes | No |
beanProperty | Specifies the field of the object specified by the name attribute whose value will be inserted into the JSP. | Yes | No |
beanScope | Specifies the scope (application, page, request, or session) to look in for the object specified by the name attribute. If not specified, each scope will be searched, in this order: page, request, session, and then application. | No | No |
component | Deprecated. Use the page attribute instead. | Yes | No |
controllerClass | Specifies the fully qualified class name of a controller object that is executed before this definition is inserted. | Yes | No |
controllerUrl | Specifies the URL for a controller that is executed before this definition is inserted. | Yes | No |
definition | Specifies the name of a definition to insert. | Yes | No |
flush | Accepts true or false to specify whether the JSP's output stream should be flushed before this definition is inserted. Defaults to false. | No | No |
ignore | Accepts true or false to specify whether this tag should return without error if the specified Tiles attribute does not exist. Defaults to false, which will cause a run-time exception to be thrown if the attribute does not exist. | Yes | No |
name | Specifies the name of an entity (definition or attribute) to insert. | Yes | No |
page | Specifies the URL to a page to insert into the JSP. | Yes | No |
role | Specifies the role the currently authenticated user must have for the specified attribute to be inserted. If the user is not in the specified role, the attribute will not be inserted. | Yes | No |
template | Deprecated. Originally for compatibility with the now-defunct Template Tag Library. Use the page attribute instead. | Yes | No |
The following example illustrates the basic usage of the insert tag:
<tiles:insert attribute="header"/>
This example inserts an attribute named "header" into a JSP.
To insert a definition, you use the definition attribute, as shown next:
<tiles:insert definition="tabLayout"/>
This example inserts an entire definition into a JSP.
As mentioned, you can also use the insert tag to create and insert a definition:
<tiles:insert page="/layouts/tabLayout.jsp"> <tiles:put name="header" value="/tabHeader.jsp"/> <tiles:put name="body" value="/search.jsp"/> <tiles:put name="footer" value="/tabFooter.jsp"/> </tiles:insert>
This type of insertion is useful for declaring the attributes that get passed to a layout JSP from inside the JSP instead of in a Tiles configuration file.
The put tag is used to define an attribute for a definition. There are two ways that the value for the attribute can be specified. The value can be specified with the value attribute, or the value can be placed between opening and closing put tags, as shown next:
<tiles:put name="header">value goes here</tiles:put>
Attribute | Description | Accepts JSP Expression | Required |
---|---|---|---|
beanName | Specifies the name of an object whose value will be used for this attribute. If the property attribute is also specified, one of the fields of the object defined by this attribute will have its getter method called to return the object whose value will be used for this attribute. | Yes | No |
beanProperty | Specifies the field of the object specified by the name attribute whose value will be used for this attribute. | Yes | No |
beanScope | Specifies the scope (application, page, request, or session) to look in for the object specified by the name attribute. If not specified, each scope will be searched, in this order: page, request, session, and then application. | No | No |
content | Deprecated. Originally for compatibility with the now-defunct Template Tag Library. Use the value attribute instead. | Yes | No |
direct | Deprecated. Originally for compatibility with the now-defunct Template Tag Library. Use the value attribute instead. | No | No |
name | Specifies the name for the attribute. | No | No |
role | Specifies the role the currently authenticated user must have for this attribute to be created. If the user is not in the role, this attribute will not be created. | Yes | No |
type | Specifies the type (string, page, or definition) of the value. If present, it indicates how the value specified with the value attribute is treated. | No | No |
value | Specifies the value for the attribute. | Yes | No |
The following example illustrates the basic usage of the put tag:
<tiles:definition name="mainLayout" page="/layouts/main.jsp"> <tiles:put name="header" value="/layouts/header.jsp"/> <tiles:put name="footer" value="/layouts/footer.jsp"/> </tiles:definition>
Defining attributes with the put tag is as simple as specifying their names and values.
The putList tag is used to define a list attribute (of java.util.List type) containing an ordered collection of individual attributes. The elements of the list are set by nesting instances of the add tag or instances of this tag. This tag must be nested inside either the definition tag or the insert tag.
Attribute | Description | Accepts JSP Expression | Required |
---|---|---|---|
name | Specifies the name of the attribute. | No | Yes |
The following example illustrates how to use the putList tag:
<tiles:insert page="/mainLayout.jsp"> <tiles:putList name="menu"> <tiles:add value="Home"/> <tiles:add value="Products"/> <tiles:add value="Search"/> </tiles:putList> </tiles:insert>
This example creates a java.util.List-based Tiles attribute named menu containing the values specified with the nested add tags.
You can also create hierarchical structures with the putList tag by nesting instances of the putList tag inside itself, as shown next:
<tiles:putList name="menu"> <tiles:add value="Home"/> <tiles:putList name="Products"> <tiles:add value="Products Menu Item 1"/> <tiles:add value="Products Menu Item 2"/> </tiles:putList> <tiles:add value="Search"/> </tiles:putList>
Tiles allows you to nest the putList tags to any level for whatever hierarchal structure you need.
The useAttribute tag is used to store the value of a Tiles attribute in a JSP scripting variable. Additionally, this tag allows you to specify which scope the JSP scripting variable should be placed in.
Attribute | Description | Accepts JSP Expression | Required |
---|---|---|---|
classname | Deprecated. This attribute is no longer used. | No | No |
id | Specifies the name of the JSP variable that will hold the specified attribute's value. | No | No |
ignore | Accepts true or false to specify whether this tag should return without error if the specified Tiles attribute does not exist. Defaults to false, which will cause a run-time exception to be thrown if the attribute does not exist. | Yes | No |
name | Specifies the name of a Tiles attribute whose value should be stored. | Yes | Yes |
scope | Specifies the scope (application, page, request, or session) in which the JSP scripting variable defined by the id attribute will be stored. If not specified, the JSP scripting variable will be stored in page scope. | No | No |
The following example illustrates how to use the useAttribute tag:
<tiles:useAttribute name="title"/>
This example stores the value of the Tiles attribute named title in a JSP scripting variable with the same name.
If you want to store the value in a JSP scripting variable with a different name, you must use the id attribute, as shown next:
<tiles:useAttribute name="title"/>
Additionally, you can specify the scope of the JSP scripting variable that the attribute value will be stored in with the scope attribute:
<tiles:useAttribute name="title" scope="session"/>