Chinaunix首页 | 论坛 | 博客
  • 博客访问: 341160
  • 博文数量: 329
  • 博客积分: 2633
  • 博客等级: 少校
  • 技术积分: 3633
  • 用 户 组: 普通用户
  • 注册时间: 2011-04-22 15:43
文章分类

全部博文(329)

文章存档

2013年(244)

2012年(46)

2011年(39)

我的朋友

分类: 系统运维

2012-03-21 20:44:53

Tiles框架的提出背景
传统的GUI工具包,如Java AWT和Java Swing,都提供了一些功能强大的布局管理器,它们指定各个视图组件在窗口中的分布位置。布局管理器有助于创建复合式的复杂界面,一个复合式界面由一些简单的基本界面组成。
利用布局管理器来创建GUI界面有以下优点:
         可重用性:基本界面可以被重用,组合成各种不同的复合式界面
          可扩展性:可以方便的扩展基本界面,从而创建更复杂的界面(其实此处我的感觉并非如此,可扩展性并不是为了创建复杂界面的,越是复杂的界面在比较独立的情况下更容易创建。)
        可维护性:每个基本界面之间相互独立,当复合式界面中的局部区域发生变化,不会影响其它区域
         不幸的是,JSP技术本身并没有直接提供布局或布局管理器。为了简化Web页面的开发,提高可重 用性和可扩展性,Struts Tiles框架提供了一种模板机制,模板定义了网页的布局,同一模板可以被多个Web页面共用。此外,Tiles框架还允许定义可重用的Tiles组件, 它可以描述一个完整的网页,也可以描述网页的局部内容。简单的Tiles组件可以被组合或扩展成为更复杂的Tiles组件。
Tiles框架的基本用法:
       使用Tiles框架大大提高了视图层程序代码的可重用性、可扩展性和可维护性,也增加了开发视图的难度和复杂度,在使用Tiles框架之前一定要结合Web应用的规模。
在开发Web站点时,常常要求同一站点的所有Web页面保持一致的外观,比如有相同的 布局、页头、页尾和菜单。 网页被划分为四个部分:Header、Menu、Footer和Content。对于同一站点的所有Web页 面,Header、Menu和Footer部分的内容相同,仅仅Content部分的内容不相同。如果采用基本的JSP语句来编写所有的Web页面,显然 会导致大量的重复编码,增加开发和维护成本。
    Tiles框架为创建Web页面提供了一种模板机制,它能将网页的布局和内容分离。它允许先创建模板,然后在运行时动态地将内容插入到模板中。Tiles框架建立在JSP的include指令的基础上,但它提供了比JSP的include指令更强大的功能。
Tiles框架具有如下特性:
创建可重用的模板
动态构建和装载页面
定义可重用的Tiles组
支持国际化
Tiles框架包含以下内容:
Tiles标签库
Tiles组件的配置文件
TilesPlugIn插件
采用JSP include指令来创建复合式页面,已经在提高代码可重用性方面迈出了正确的一步。通过JSP include指令把这些相同内容包含进来,这样提高了代码的可重用性。但是JSP include指令不能完全避免代码冗余。
   Tiles标签库的tiles:insert标签和JSP include指令具有相同的功能,也能把其他的JSP页面插入到当前页面中。例如,以下两条语句的作用是相同的:
       标签的page属性指定被插入的JSP文件,flush属性的可选值包括true和false,当flush属性为true,表示在执行插入操作之前,先调用当前页面的输出流的flush()方法。
       用tiles:insert标签取代JSP include指令来创建复合式页面,代码仅有稍微的差别,两者的利弊也很相似。单纯使用tiles:insert标签来创建复合式页面,还没有充分发挥Tiles框架的优势。
     通俗的讲,Tiles模板是一种描述页面布局的JSP页面。Tiles模板仅仅定义Web页面的样式,而不指定内容。在Web应用运行时,才把特定内容插入到模板页面中。同一模板可以被多个Web页面共用。
      使用模板,可以轻松的实现Web应用的所有页面保持相同的外观和布局,无需为每个页面硬编码。在一个应用中,大多数页面使用同一模板,某些页面可能需要不同的外观,使用其他的模板,因此一个应用可能有一个以上模板。
        在模板文件layout.jsp中定义了网页的布局,但没有指定各部分具体的内容。layout.jsp中包含多个tiles:insert标签,它的attribute属性仅仅指定了待插入内容的逻辑名,而没有指定真正被插入的文件。
         采用Tiles模板机制,大大提高了代码的可重用性和可维护性,模板中包含了网页共同的布局。如果布局发生变化,只需要修改模板文件,无需修改具体的网页文件。
   Tiles框架允许在专门的XML文件中配置Tiles组件。例如,以下代码定义了一个名为"index-definition"的Tiles组件,它描述整个index.jsp网页:
  
     
        
        
        
  
     definition元素的name属性指定Tiles组件的名字,path属性指定Tiles组件使用的模板,definition元素的put子元素用于向模板中插入具体的网页内容。
        TilesPlugin插件用于加载Tiles组件的配置文件。在plug-in元素中包含几个set-property子元素,用于向TilesPlugin插件传入附加的参数:
     ·definitions-config参数:指定Tiles组件的配置文件,如果有多个配置文件,则它们之间用逗号分隔。
     ·definitions-parser-validate参数:指定XML解析器是否验证Tiles配置文件,可选值包括true和false,默认值为true。
           通过Struts Action来调用Tiles组件
     如果Tiles组件代表完整的网页,可以直接通过Struts Action来调用Tiles组件。例如,如果希望通过Struts Action来调用名为"index-definition"的Tiles组件,可以在Struts配置文件中配置如下Action映射:
   path="/index"
          type="org.apache.struts.actions.ForwardAction"
          parameter="index-definition">
     接下来通过浏览器访问 ,该请求先被转发到 ForwardAction,ForwardAction再把请求转发给名为"index-definition"的Tiles组件,最后在浏览器端,用 户将看到和index.jsp相同的页面。
     通过Struts Action来调用Tiles组件,可以充分发挥Struts框架负责流程控制的功能。此外,可以减少JSP文件的数目。例如,如果直接通过Struts Action来调用名为"index-definition"的Tiles组件,就不必再创建index.jsp文件。
     Tiles组件是一种可重用的组件。可以象搭积木一样,把简单的Tiles组件组装成复杂的Tiles组件。
可以利用Tiles组件的可扩展特性来进一步消除冗余代码。解决方法为先定义一 个包含这两个Tiles组件的共同内容的父类Tiles组件,命名为"base-definition",然后再让"index-definition" 和"product-definition"这两个Tiles组件继承这个父类组件。
     一个Tiles组件继承另一个Tiles组件的语法如下,其中definition元素的extends属性指定被扩展的父类Tiles组件:
 
Tiles标签库的标签和JSP include指令具有相同的功能,也能把其他的JSP
页面插入到当前页面中。例如,以下两条语句的作用是相同的:


标签的page 属性指定被插入的JSP 文件;flush属性的可选值包括true 和
false。当flush的属性值为true时,表示在执行插入操作之前,先调用当前页面的输出流的
flush()方法。

开发步骤

(1)安装Tiles标签库所需的文件。

以下文件必须位于WEB-INF/lib 目录中:

l struts.jar
l commons-digester.jar
l commons-beanutils.jar
l commons-collections.jar
l commons-logging.jar
此外,应该把Tiles标签库的定义文件struts-tiles.tld拷贝到WEB-INF目录下。
(2)在web.xml文件中配置如下元素:

/WEB-INF/struts-tiles.tld
/WEB-INF/struts-tiles.tld


(3)创建index.jsp和product.jsp文件。
修改16.2 节的例程16-8(index.jsp)和例程16-9(product.jsp),在index.jsp和product.jsp
文件的开头,通过<%@ taglib>指令引入Tiles标签库,然后把源代码中的JSP include指令
改为标签.

index.jsp

<%@ page contentType="text/html; charset=UTF-8" %> <%@ taglib uri="/WEB-INF/struts-tiles.tld" prefix="tiles" %> <html> <head> <title>TilesTaglibs Sampletitle> head> <body > <%-- One table lays out all of the content for this page --%> <table width="100%" height="100%"> <tr> <%-- Sidebar section --%> <td width="150" valign="top" align="left" bgcolor="#CCFFCC"> <tiles:insert page="sidebar.jsp" flush="true"/> td> <%-- Main content section --%> <td height="100%" width="*"> <table width="100%" height="100%"> <tr> <%-- Header section --%> <td valign="top" height="15%"> <tiles:insert page="header.jsp" flush="true"/> td> <tr> <tr> <%-- Content section --%>


例程16-11 product.jsp

<%@ page contentType="text/html; charset=UTF-8" %> <%@ taglib uri="/WEB-INF/struts-tiles.tld" prefix="tiles" %> <html> <head> <title>TilesTaglibs Sampletitle> head> <body > <%-- One table lays out all of the content for this page --%> <table width="100%" height="100%"> <tr> <%-- Sidebar section --%> <td width="150" valign="top" align="left" bgcolor="#CCFFCC"> <tiles:insert page="sidebar.jsp" flush="true"/> td> <%-- Main content section --%> <td height="100%" width="*"> <table width="100%" height="100%"> <tr> <%-- Header section --%> <td valign="top" height="15%"> <tiles:insert page="header.jsp" flush="true"/> td> <tr> <tr> <%-- Content section --%> <td valign="top" height="*"> <tiles:insert page="productContent.jsp" flush="true"/>tr> <tr> <%-- Footer section --%> <td valign="bottom" height="15%"> <tiles:insert page="footer.jsp" flush="true"/> td> tr> table> td> tr> table> body >




以上虽然用到了但是页面还是存在很多重复代码,可以采用 Tiles模版机制实现

Tiles 模板 :

通俗地讲,Tiles 模板是一种描述页面布局的JSP 页面。Tiles 模板只定义了Web 页面
的样式,而不指定内容。在Web 应用运行时,才把特定内容插入到模板页面中。同一模板
可以被多个Web页面共用。


使用模板,可以轻松地实现Web 应用的所有页面保持相同的外观和布局,而无需为每
个页面硬编码。在一个应用中,大多数页面使用同一个模板,某些页面可能需要不同的外
观,而使用其他的模板,因此一个应用可能有一个以上的模板。

以下是在tilestaglibs应用中使用Tiles模板的步骤:
(1)安装Tiles标签库所需的文件.

(2)在web.xml文件中配置元素.
(3)定义模板文件
例layout.jsp

<%@ page contentType="text/html; charset=UTF-8" %> <%@ taglib uri="/WEB-INF/struts-tiles.tld" prefix="tiles"%> <html> <head> <title>TilesTaglibs Sampletitle> head> <body > <%-- One table lays out all of the content --%> <table width="100%" height="100%"> <%-- Sidebar section --%> <tr> <td width="150" valign="top" align="left" bgcolor="#CCFFCC"> <tiles:insert attribute="sidebar"/> td> <%-- Main content section --%> <td valign="top" height="100%" width="*"> <table width="100%" height="100%"> <tr> <%-- Header section --%> <td height="15%"> <tiles:insert attribute="header"/> td> <tr> <tr> <%-- Content section --%> <td valign="top" height="*"> <tiles:insert attribute="content"/> td> tr> <tr> <%-- Footer section --%> <td valign="bottom" height="15%"> <tiles:insert attribute="footer"/> td> tr> table> td> tr> table> body> html>


在模板文件layout.jsp 中定义了网页的布局,但没有指定各部分的具体内容。在
layout.jsp中包含了多个标签,它的attribute属性仅仅指定了待插入内容的逻辑名,而没有指定真正被插入的文件。
(4)在index.jsp和product.jsp中运用Tiles模板

例 index.jsp

<%@ page contentType="text/html; charset=UTF-8" %> <%@ taglib uri="/WEB-INF/struts-tiles.tld" prefix="tiles" %> <tiles:insert page="layout.jsp" flush="true"> <tiles:put name="sidebar" value="sidebar.jsp"/> <tiles:put name="header" value="header.jsp"/> <tiles:put name="content" value="indexContent.jsp"/> <tiles:put name="footer" value="footer.jsp"/> tiles:insert>

例 product.jsp

<%@ page contentType="text/html; charset=UTF-8" %> <%@ taglib uri="/WEB-INF/struts-tiles.tld" prefix="tiles" %> <tiles:insert page="layout.jsp" flush="true"> <tiles:put name="sidebar" value="sidebar.jsp"/> <tiles:put name="header" value="header.jsp"/> <tiles:put name="content" value="productContent.jsp"/> <tiles:put name="footer" value="footer.jsp"/> tiles:insert>



在index.jsp 和product.jsp 中,标签指定插入的模板文件,index.jsp 和
product.jsp均使用相同的模板文件layout.jsp。标签中包含了若干子标
签,它指定插入到模板中的具体内容。标签的name 属性和模板文件中的
标签的attribute属性匹配,标签的value属性指定插入到模板中的具
体JSP文件。


采用Tiles模板机制,大大提高了代码的可重用性和可维护性,模板中包含了网页共同
的布局。如果布局发生变化,就只需要修改模板文件,而无需修改具体的网页文件。不过,
从例程16-13 和16-14 中可以看出,尽管index.jsp 和product.jsp 文件的长度都缩短了,但
是两者还是存在重复代码。

采用Tiles 模板和Tiles 组件创建复合式网页

为了最大程度地提高代码的可重用性和灵活性,Tiles 框架引入了Tiles 组件的概念。
Tiles 组件可以代表一个完整的网页,也可以代表网页的一部分。简单的Tiles 组件可以组
合成复杂的Tiles组件,或被扩展为复杂的Tiles组件。

Tiles组件的基本使用方法
Tiles框架允许在专门的XML文件中配置Tiles组件。例如,以下代码定义了一个名为
“index-definition”的Tiles组件,它描述整个index.jsp网页:

xml文件

<tiles-definitions> <definition name="index-definition" path="/layout.jsp"> <put name="sidebar" value="sidebar.jsp"/> <put name="header" value="header.jsp"/> <put name="content" value="indexContent.jsp"/> <put name="footer" value="footer.jsp"/> definition> tiles-definitions>


元素的name 属性指定Tiles组件的名字,path属性指定Tiles组件使用的模
板,元素的子元素用于向模板中插入具体的网页内容。

步骤



(1)安装Tiles标签库所需的文件,
(2)在web.xml文件中配置元素,
(3)在专门的XML 文件中配置Tiles 组件, 在本例中把这个配置文件命名为
tiles-defs.xml,这个文件位于WEB-INF目录下。例为tiles-defs.xml文件的代码。
例 tiles-defs.xml

xml version="1.0" encoding="ISO-8859-1" ?> DOCTYPE tiles-definitions PUBLIC "-//Apache Software Foundation//DTD Tiles Configuration 1.1//EN" ""> <tiles-definitions> <definition name="index-definition" path="/layout.jsp"> <put name="sidebar" value="sidebar.jsp"/> <put name="header" value="header.jsp"/> <put name="content" value="indexContent.jsp"/> <put name="footer" value="footer.jsp"/> definition> <definition name="product-definition" path="/layout.jsp"> <put name="sidebar" value="sidebar.jsp"/> <put name="header" value="header.jsp"/> <put name="content" value="productContent.jsp"/> <put name="footer" value="footer.jsp"/> definition> tiles-definitions>

以上代码定义了两个Tiles组件,它们分别代表完整的index.jsp和product.jsp页面。

(4)在Strut配置文件中配置TilesPlugin插件,其代码如下

<plug-in className="org.apache.struts.tiles.TilesPlugin" > <set-property property="definitions-config" value="/WEB-INF/tiles-defs.xml" /> <set-property property="definitions-parser-validate" value="true" /> plug-in>


TilesPlugin 插件用于加载Tiles 组件的配置文件。在元素中包含几个
子元素,用于向TilesPlugin插件传入附加的参数:
l definitions-config 参数:指定Tiles 组件的配置文件,如果有多个配置文件,则它
们之间用逗号分隔。
l definitions-parser-validate 参数:指定XML 解析器是否验证Tiles 配置文件,可选
值包括true和false,默认值为true。


(5)在web.xml文件中配置ActionServlet。


为了保证在Web 应用启动时加载TilesPlugin 插件,应该加入ActionServlet 控制器,
ActionServlet 控制器在初始化时能加载所有的插件。以下是在web.xml 文件中配置
ActionServlet的代码:

<servlet> <servlet-name>actionservlet-name> <servlet-class>org.apache.struts.action.ActionServletservlet-class> <init-param> <param-name>configparam-name> <param-value>/WEB-INF/struts-config.xmlparam-value> init-param> <load-on-startup>3load-on-startup> servlet> <servlet-mapping> <servlet-name>actionservlet-name> <url-pattern>*.dourl-pattern> servlet-mapping>



(6)在index.jsp和product.jsp中插入Tiles组件

例index.jsp

<%@ page contentType="text/html; charset=UTF-8" %> <%@ taglib uri="/WEB-INF/struts-tiles.tld" prefix="tiles" %> <tiles:insert definition="index-definition"/> 例product.jsp <%@ page contentType="text/html; charset=UTF-8" %> <%@ taglib uri="/WEB-INF/struts-tiles.tld" prefix="tiles" %> <tiles:insert definition="product-definition"/>


通过Struts Action来调用Tiles组件

如果Tiles 组件代表完整的网页,那么可以直接通过Struts Action 来调用Tiles 组件。
例如,如果希望通过Struts Action来调用小节定义的名为“index-definition”的Tiles
组件,那么可以在Struts配置文件中配置如下Action映射:

<action-mappings> <action path="/index" type="org.apache.struts.actions.ForwardAction" parameter="index-definition"> action> action-mappings>



接下来通过浏览器访问,该请求先被转发到
ForwardAction,ForwardAction再把请求转发给名为“index-definition”的Tiles组件,最后
在浏览器端,用户将看到和index.jsp相同的页面。
通过Struts Action来调用Tiles组件,可以充分发挥Struts框架负责流程控制的功能。
此外,还可以减少JSP 文件的数目。例如,如果直接通过Struts Action 来调用名为
“index-definition”的Tiles组件,就不必再创建index.jsp文件。

Tiles组件的组合



组合式开发步骤:

(1)在tiles-def.xml文件中重新定义“sidebar-definition”,“index-definition”和“productdefinition”
这三个Tiles组件。在一个Tiles组件中包含另一个Tiles组件的语法为:


……

以上子元素的value 属性指定被包含的Tiles 组件的名字,type 属性设置为
“definition”,表示value属性指定的是Tiles组件,而不是JSP文件。以下是tiles-def.xml
文件的代码。

tiles-def.xml

xml version="1.0" encoding="ISO-8859-1" ?> DOCTYPE tiles-definitions PUBLIC "-//Apache Software Foundation//DTD Tiles Configuration//EN" ""> <tiles-definitions> <definition name="sidebar-definition" path="/sidebar-layout.jsp"> <put name="top" value="flags.jsp"/> <put name="bottom" value="sidebar-links.jsp"/> definition> <definition name="index-definition" path="/layout.jsp"> <put name="sidebar" value="sidebar-definition" type="definition"/> <put name="header" value="header.jsp"/> <put name="content" value="indexContent.jsp"/> <put name="footer" value="footer.jsp"/> definition> <definition name="product-definition" path="/layout.jsp"> <put name="sidebar" value="sidebar-definition" type="definition"/> <put name="header" value="header.jsp"/> <put name="content" value="productContent.jsp"/> <put name="footer" value="footer.jsp"/> definition> tiles-definitions>


(2)创建名为“sidebar-definition”的Tiles组件的相关JSP文件。
名为“sidebar-definition”的Tiles 组件的模板文件为sidebar-layout.jsp,被插入到这个
模板中的两个JSP 文件分别为flags.jsp 和sidebar-links.jsp。例程16-19、16-20 和16-21 分
别为这几个JSP文件的源代码。

sidebar-layout.jsp

<%@ page contentType="text/html; charset=UTF-8" %> <%@ taglib uri="/WEB-INF/struts-tiles.tld" prefix="tiles"%> <table > <tr> <%-- Sidebar top component --%> <tiles:insert attribute="top"/> tr> <tr> <%-- Sidebar bottom component --%> <tiles:insert attribute="bottom"/> tr> table>


sidebar-links.jsp

<%-- Sidebar bottom component --%> <td> <table> <tr> <td> <font size="5">Linksfont><p> <a href="index.jsp">Homea><br> <a href="product.jsp">Productsa><br> <a href="">Hot Link1a><br><a href="">Hot Link2a><br> <a href="">Hot Link3a><br> td> tr> table> td>


flags.jsp

<%-- Sidebar top component --%> <td width="150" height="65" valign="top" align="left"> <a href=""><img src="chinese.gif" border="0"/>a> <a href=""><img src="usa.gif" border="0"/>a> td>





继承

一个Tiles组件继承另一个Tiles组件的语法如下,其中元素的extends 属性
指定被扩展的父类Tiles组件:


tiles-def.xml

xml version="1.0" encoding="ISO-8859-1" ?> DOCTYPE tiles-definitions PUBLIC "-//Apache Software Foundation//DTD Tiles Configuration 1.1//EN" ""> <tiles-definitions> <definition name="sidebar-definition" path="/sidebar-layout.jsp"> <put name="top" value="flags.jsp"/> <put name="bottom" value="sidebar-links.jsp"/> definition> <definition name="base-definition" path="/layout.jsp"> <put name="sidebar" value="sidebar-definition" type="definition"/> <put name="header" value="header.jsp"/> <put name="content" value=""/> <put name="footer" value="footer.jsp"/> definition> <definition name="index-definition" extends="base-definition"> <put name="content" value="indexContent.jsp"/> definition> <definition name="product-definition" extends="base-definition"> <put name="content" value="productContent.jsp"/> definition> tiles-definitions>


Tiles 组件是一种可重用的组件,可以像搭积木一样,把简单的Tiles 组件组装成复杂
的Tiles组件。例如,可以把名为“index-definition”的Tiles组件的左边部分拆分为独立的
Tiles组件,名为“sidebar-definition”,即组件的嵌套

 
 
阅读(7692) | 评论(2) | 转发(0) |
给主人留下些什么吧!~~

夏冰软件2012-03-23 15:28:16

博主写的不错,支持一下

十七岁的回忆2012-03-22 22:27:19

恩,是的,在复杂的东西都是简单的原件构成的,计算机---01的世界!