tiles,俗称"小部件"。由于当今界面设计的可用性要求界面必须保持一致。早期开发使用文件包含的方式来使页面模块化,类型<%@include file=""%> <jsp:include page="">之类的包含指令或jsp标签。这样导致所有包含这些的页面都必须添加类似代码。(tiles类型asp.net2.0的masterpage)
<taglib-uri>/tags/tiles.tld</taglib-uri>
<taglib-location>/WEB-INF/struts-tiles.tld </taglib-location>
</taglib>
<taglib>
<taglib-uri>/tags/bean.tld</taglib-uri>
<taglib-location>/WEB-INF/struts-bean.tld </taglib-location>
</taglib> <taglib>
<taglib-uri>/tags/html.tld</taglib-uri>
<taglib-location>/WEB-INF/html.tld </taglib-location> </taglib>
</jsp-config>
</web-app>
这些配置仅仅是为了方便使用。
Q:tiles比包含方式有哪些优先点?
A:tiles可替换,扩展,继承,代码量小,是否还有别的区别必须深入研究。
配置tiles
一、先配置web.xml
在myeclipse上加入struts支持,在WEB-INF下会出现一系列的tld,例struts-bean.tld.
在myeclipse上加入struts支持,在WEB-INF下会出现一系列的tld,例struts-bean.tld.
<web-app xmlns="http://java.sun.com/xml/ns/j2ee" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" version="2.4" xsi:schemaLocation="http://java.sun.com/xml/ns/j2ee http://java.sun.com/xml/ns/j2ee/web-app_2_4.xsd">
<jsp-config><taglib>
<taglib-uri>/tags/tiles.tld</taglib-uri>
<taglib-location>/WEB-INF/struts-tiles.tld </taglib-location>
</taglib>
<taglib>
<taglib-uri>/tags/bean.tld</taglib-uri>
<taglib-location>/WEB-INF/struts-bean.tld </taglib-location>
</taglib> <taglib>
<taglib-uri>/tags/html.tld</taglib-uri>
<taglib-location>/WEB-INF/html.tld </taglib-location> </taglib>
</jsp-config>
</web-app>
这些配置仅仅是为了方便使用。
webroot下增加如下结构的文件夹
webroot
--tiles
--layout
--css
--page
并分别放header.html,body.html,footer.html放在webroot-tiles文件夹下,都只包括片段代码类似<h1>this is header html!</h1>
二、第一种tiles
1)定义一个模板页simpletemplate.jsp放在webroot-tiles-layout文件夹下
<%@ page language="java" pageEncoding="GBK"%> <%@ taglib uri="/tags/tiles.tld" prefix="tiles" %> <%@ taglib uri="/tags/html.tld" prefix="html" %> <%@ taglib uri="/tags/bean.tld" prefix="bean" %>//web.xml中定义好的taglib-uri只是为了这里方便使用,如果这里直接用/WEB-INF/struts-bean.tld也可以了 <!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN"> <html><head></head><body>
<div><tiles:insert attribute="header"/></div>//页头
<div><tiles:insert attribute="body"/></div>页内容
<div><tiles:insert attribute="footer"/></div>页脚
</body>
</html>
2)定义一个使用该模板的页面simple.jsp放在webroot-page文件夹下
<%@ page pageEncoding="GBK"%> <%@ taglib uri="/tags/tiles.tld" prefix="tiles" %> <tiles:insert page="/tiles/layout/template.jsp" flush="true">
<tiles:put name="header" type="page" value="/tiles/header.html" /> //如果在模板内有的属性在此处没有定义,则出错(如要忽略该错误,必须在simpletemplate.jsp中的<tiles:insert attribute="header" ignore="ture"/>加上ignore="true") <tiles:put name="body" type="page" value="/tiles/body.html" /> //或者可以使用<tiles:put name="body" type="string" value="this is a body">;value=(这里可以用expressionlanguage或者html代码) <tiles:put name="footer" type="page" value="/tiles/footer.html" /> </tiles:insert>
这样就定义完成一个简单的tiles应用
三、按照第二中的tiles,如果要添加一个页面 都必须要添加一个内容页面,类似body.html,为了避免页面越来越多,可以使用body-wrap技术。
<tiles:put name="body"><input type="button" value="test" tile="123"/></tiles:put>//这样就少建立一个body文件,body内容直接包含在<tiles:input></tiles:input>中了
四、定义,扩展