Tiles框架特性和内容
Tiles框架为创建Web页面提供了一种模板机制,它能将网页的布局和内容分离。它允许先创建模板,然后在运行时动态地将内容插入到模板中。Tiles 框架建立在JSP的include指令的基础上,但它提供了比JSP的 include指令更强大的功能。Tiles框架具有如下特性:
◆创建可重用的模板
◆动态构建和装载页面
◆定义可重用的Tiles组件
◆支持国际化
Tiles框架包含以下内容:
◆Tiles标签库
◆Tiles组件的配置文件
◆TilesPlugIn插件
在开发Web站点时,常常要求同一站点的所有Web页面保持一致的外观,比如有相同的布局、页头、页尾和菜单。
采用基本的JSP语句创建复合式网页
创建动态Web页面的最基本的办法是为每个页面创建独立的JSP文件。如果网页的相同部分发生需求变更,必须手工修改所有的JSP文件。可见,采用基本的JSP语句来编写上述网页,会导致JSP代码的大量冗余,增加开发与维护成本。
采用JSP的include指令创建复合式网页
为了减少代码的冗余,可以把index.jsp和product.jsp中相同部分放在单独的JSP文件中,然后在index.jsp和 product.jsp文件中通过JSP include指令把其他JSP文件包含进来。这样提高了代码的可重用性。但是JSP include指令不能完全避免代码冗余,尽管这种方案减少了重复代码,但JSP文件的数量增加了,由原来的2个文件增加到7个文件,所以软件的复杂度也增加了。
采用Tiles:Insert标签创建复合式网页
Tiles标签库的tiles:insert标签和JSP include指令具有相同的功能,也能把其他的JSP页面插入到当前页面中。用tiles:insert标签取代JSP include指令来创建复合式页面,代码仅有稍微的差别,两者的利弊也很相似。单纯使用tiles:insert标签来创建复合式页面,还没有充分发挥 Tiles框架的优势。
以下两条语句的作用是相同的:
< ?xml:namespace prefix = jsp />< jsp:include page="indexContent.jsp">< /jsp:include> < ?xml:namespace prefix = tiles />< tiles:insert page="indexContent.jsp">< /tiles:insert> |
采用Tiles模板创建复合式网页
尽管使用了tiles:insert标签,index.jsp和product.jsp文件还是存在很多的重复代码。为了提高Web页面的可重用性和可维护性,可以引入Tiles的模板机制。通俗的讲,Tiles模板是一种描述页面布局的JSP页面。Tiles模板仅仅定义Web页面的样式,而不指定内容。在Web应用运行时,才把特定内容插入到模板页面中。同一模板可以被多个Web页面共用。使用模板,可以轻松的实现Web应用的所有页面保持相同的外观和布局,无需为每个页面硬编码。在一个应用中,大多数页面使用同一模板,某些页面可能需要不同的外观,使用其他的模板,因此一个应用可能有一个以上模板。
< %@ taglib uri="/WEB-INF/struts-tiles.tld" prefix="tiles"%> < tiles:insert attribute="sidebar">< /tiles:insert> < tiles:insert attribute="header">< /tiles:insert> < tiles:insert attribute="content">< /tiles:insert> < tiles:insert attribute="footer">< /tiles:insert> < %@ 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 value="sidebar.jsp" name="sidebar">< /tiles:put> < tiles:put value="header.jsp" name="header" >< /tiles:put> < tiles:put value="indexContent.jsp" name="content">< /tiles:put> < tiles:put value="footer.jsp" name="footer" >< /tiles:put> < /tiles:insert> |
采用Tiles模板机制,大大提高了代码的可重用性和可维护性,模板中包含了网页共同的布局。如果布局发生变化,只需要修改模板文件,无需修改具体的网页文件。不过,从例程16-13和16-14可以看出,尽管 index.jsp和product.jsp文件的长度都缩短了,但是两者还是存在重复代码。
Tiles组件的基本使用方法
为了最大程度的提高代码的可重用性和灵活性,Tiles框架引入了Tiles组件的概念。Tiles组件可以代表一个完整的网页,也可以代表网页的一部分。简单的Tiles组件可以组合成复杂的Tiles组件,或被扩展为复杂的Tiles组件。
Tiles框架允许在专门的XML文件中配置Tiles组件。例如,以下代码定义了一个名为"index-definition"的Tiles组件,它描述整个index.jsp网页:
< TILES-DEFINITIONS> < DEFINITION name="index-definition" path="/layout.jsp"> < put value="sidebar.jsp" name="sidebar">< /put> < put value="header.jsp" name="header">< /put> < put value="indexContent.jsp" name="content">< /put> < put value="footer.jsp" name="footer" >< /put> < /DEFINITION> < /TILES-DEFINITIONS> |
definition元素的name属性指定Tiles组件的名字,path属性指定Tiles组件使用的模板,definition元素的put子元素用于向模板中插入具体的网页内容。
例程16-15 tiles-defs.xml
< ?xml version="1.0" encoding="ISO-8859-1" ?> -config_1_1.dtd"> < TILES-DEFINITIONS> < DEFINITION name="index-definition" path="/layout.jsp"> <:put value="sidebar.jsp" name="sidebar">< /put> <:put value="header.jsp" name="header">< /put> <:put value="indexContent.jsp" name="content">< /put> <:put value="footer.jsp" name="footer">< /put> < /DEFINITION> < DEFINITION name="product-definition" path="/layout.jsp"> < put value="sidebar.jsp" name="sidebar">< /put> < put value="header.jsp" name="header" >< /put> < put value="productContent.jsp" name="content">< /put> < put value="footer.jsp" name="footer" >< /put> < /DEFINITION> < /TILES-DEFINITIONS> |
以上代码定义了两个Tiles组件,它们分别代表完整的index.jsp和product.jsp页面。
(4)在Strut配置文件中配置TilesPlugin插件,代码如下:
< PLUG-IN className="org.apache.struts.tiles.TilesPlugin"> < SET-PROPERTY value="/WEB-INF/tiles-defs.xml" property="definitions-config" /> < SET-PROPERTY value="true" property="definitions-parser-validate" /> < /PLUG-IN> |
TilesPlugin插件用于加载Tiles组件的配置文件。在plug-in元素中包含几个set-property子元素,用于向TilesPlugin插件传入附加的参数:
◆definitions-config参数:指定Tiles组件的配置文件,如果有多个配置文件,则它们之间用逗号分隔。
◆definitions-parser-validate参数:指定XML解析器是否验证Tiles配置文件,可选值包括true和false,默认值为true。
(5)在web.xml文件中配置ActionServlet
为了保证在Web应用启动时加载TilesPlugin插件,应该加入ActionServlet控制器,ActionServlet控制器在初始化时能加载所有的插件。以下是在web.xml文件中配置ActionServlet的代码:
< SERVLET> < SERVLET-NAME>action< /SERVLET-NAME> < SERVLET-CLASS>org.apache.struts.action.ActionServlet< /SERVLET-CLASS> < INIT-PARAM> < PARAM-NAME>config< /PARAM-NAME> < PARAM-VALUE>/WEB-INF/struts-config.xml< /PARAM-VALUE> < /INIT-PARAM> < LOAD-ON-STARTUP>3< /LOAD-ON-STARTUP> < /SERVLET> < SERVLET-MAPPING> < SERVLET-NAME>action< /SERVLET-NAME> < URL-PATTERN>*.do< /URL-PATTERN> < /SERVLET-MAPPING> |
(6)在index.jsp和product.jsp中插入Tiles组件,参见例程16-16和例程16-17:
例程16-16 index.jsp
< %@ page contentType="text/html; charset=UTF-8" %> < %@ taglib uri="/WEB-INF/struts-tiles.tld" prefix="tiles" %> < tiles:insert definition="index-definition">< /tiles:insert> |
例程16-17 product.jsp
< CCID_NOBR>
bordercolorlight = "black" bordercolordark = "#FFFFFF" align="center">
< CCID_CODE> < %@ page contentType="text/html; charset=UTF-8" %> < %@ taglib uri="/WEB-INF/struts-tiles.tld" prefix="tiles" %> < tiles:insert definition="product-definition">< /tiles:insert> |
通过Struts Action来调用Tiles组件
如果Tiles组件代表完整的网页,可以直接通过Struts Action来调用Tiles组件。例如,如果希望通过Struts Action来调用16.5.1节定义的名为"index-definition"的Tiles组件,可以在Struts配置文件中配置如下Action 映射:
< ACTION-MAPPINGS> < ACTION path="/index" P <> 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组件的组合与扩展
Tiles 组件是一种可重用的组件。可以象搭积木一样,把简单的Tiles组件组装成复杂的Tiles组件,例如,可以把名为"index-definition" 的Tiles组件的左边部分拆分为独立的Tiles组件,名为"sidebar-definition"。
< DEFINITION name="index-definition" path="/layout.jsp"> < put value="sidebar-definition" name="sidebar" type="definition">< /put> …… < /DEFINITION> |
以上put子元素的value属性指定被包含的Tiles组件的名字,type属性设为"definition",表示value属性指定的是Tiles组件,而不是JSP文件。
< DEFINITION name="index-definition" extends="base-definition"> |
教你如何精通Struts:Tiles框架的更多相关文章
-
Struts Tiles框架使用(转)
原文:Struts Tiles框架使用 Tiles框架 ++YONG原创,转载请声明 Tiles框架为创建Web页面提供了一种模板机制,它能将网页的布局和内容分离.它用模板定义网页布局,每个页面模板都 ...
-
掌握Tiles 框架 (一)---Tiles入门和Tiles 框架和体系结构
掌握Tiles 框架 (一)---Tiles入门和Tiles 框架和体系结构 入门 本教程所讲述的内容 本教程讲述如何使用 Tiles 框架来创建可重用的表示组件.(在最初创建它时,Tiles 框架被 ...
-
分分钟知道tiles框架是干嘛的
分分钟知道tiles框架是干嘛的 http://blog.sina.com.cn/s/blog_a123d4d50101792d.html参考上面的文章,简单明了.让你一下子就知道这个是用来做什么的. ...
-
使用Struts 2框架实现文件下载
从服务器发送一个文件到浏览器需要以下几个步骤 把HTTP响应里的ContentType标头设置为被下载文件的内容类型.ContentType标头的作用是表明数据包里的数据是什么类型, 它由一个多媒体类 ...
-
看过《大湿教我写.net通用权限框架(1)之菜单导航篇》之后发生的事(续)——主界面
引言 在UML系列学习中的小插曲:看过<大湿教我写.net通用权限框架(1)之菜单导航篇>之后发生的事 在上篇中只拿登录界面练练手,不把主界面抠出来,实在难受,严重的强迫症啊.之前一直在总 ...
-
Springmvc整合tiles框架简单入门示例(maven)
Springmvc整合tiles框架简单入门示例(maven) 本教程基于Springmvc,spring mvc和maven怎么弄就不具体说了,这边就只简单说tiles框架的整合. 先贴上源码(免积 ...
-
SpringMVC整合Tiles框架
SpringMVC整合Tiles框架 Tiles组件 tiles-iconfig.xml Tiles是一个JSP布局框架. Tiles框架为创建Web页面提供了一种模板机制,它能将网页的布局和内容分离 ...
-
《Python3网络爬虫开发实战》PDF+源代码+《精通Python爬虫框架Scrapy》中英文PDF源代码
下载:https://pan.baidu.com/s/1oejHek3Vmu0ZYvp4w9ZLsw <Python 3网络爬虫开发实战>中文PDF+源代码 下载:https://pan. ...
-
《精通Python爬虫框架Scrapy》学习资料
<精通Python爬虫框架Scrapy>学习资料 百度网盘:https://pan.baidu.com/s/1ACOYulLLpp9J7Q7src2rVA
随机推荐
-
SQL Server:字符串函数
以下所有例子均Studnet表为例: 1. len():计算字符串长度 len()用来计算字符串的长度,每个中文汉字或英文字母都为一个长度 select sname, len(sname) from ...
-
ReSharper 卸载后 VS2012 没有提示问题
虽然ReSharper非常强大,但由于公司电脑配置太差,*卸载了.但发现卸载后,VS2012自带的提示都没有了. 网上找了下相关的解决方法.摘抄下来,作为自己笔记. 解决方法原文出处:http:// ...
-
ssh登录慢,等待输入密码时间长
有时候在ssh远程登录到其他主机上时发现登录时间太长,要等待很久才会出现输入密码的提示,google了一下,发现主要有两个问题会导致ssh登录慢: 1.使用了dns反查,这样的话当ssh某个IP时,系 ...
-
systick优先级的理解
sysTick系统嘀嗒定时器并非STM32独有的,它是Cortex内核的部分,CM3为它专门开出一个异常类型,并且在中断向量表中占有一席之地(异常号15).这样它可以很方便的移植到不同厂商出CM3内核 ...
-
MySQL 有输入输出参数的存储过程实例
1.MySQL 有输入输出参数的存储过程实例 DELIMITER // DROP PROCEDURE IF EXISTS `test`.`p_getvalue` // CREATE PROCEDURE ...
-
Android实训案例(一)——计算器的运算逻辑
Android实训案例(一)--计算器的运算逻辑 应一个朋友的邀请,叫我写一个计算器,开始觉得,就一个计算器嘛,很简单的,但是写着写着发现自己写出来的逻辑真不严谨,于是搜索了一下,看到mk(没有打广告 ...
-
[JavaScript] 后端js的模块化规范CommonJs
CommonJs概述 主要是单个文件定义的变量,函数,类都是私有的,其他文件不可见,单位的作用域 通过 exports(modules.exports)对外暴露接口,通过 require 加载模块 n ...
-
安卓易学,爬坑不易—腾讯老司机的RecyclerView局部刷新爬坑之路
前言 安卓开发者都知道,RecyclerView比ListView要灵活的多,但不可否认的里面的坑也同样埋了不少人.下面让我们看看腾讯开发工程师用实例讲解自己踩坑时的解决方案和心路历程. 话说有图有真 ...
-
用UIBezierPath数组对UIView进行镂空处理
用UIBezierPath数组对UIView进行镂空处理 效果 源码 // // CutOutClearView.h // CutOutMaskView // // Created by YouXia ...
-
spring 上下文和spring mvc上下文和web应用上下文servletContext之间的关系
要想很好理解这三个上下文的关系,需要先熟悉spring是怎样在web容器中启动起来的.spring的启动过程其实就是其IoC容器的启动过程,对于web程序,IoC容器启动过程即是建立上下文的过程. s ...