`
wezly
  • 浏览: 487293 次
  • 性别: Icon_minigender_1
  • 来自: 长沙
社区版块
存档分类
最新评论

Tiles使用简介

阅读更多

最新喜欢看一看一些比较“老旧”的技术,感觉这些东西虽然实现技术上比较老了,但是其中所蕴含的思想和构思方法还是很有借鉴意义的,随记录到博客中来慢慢品味。

一:说明
Struts1.1以后增加了Tiles包使得struts在页面的处理方面多了一种选择.并且更容易实现
代码的重用。
Tiles中对页面的划分有点象jakarta的另外一个项目Turbine中的TDK。增加了layout的概念.
其实就是把一个页面划分为几块。通常的来说一个页面大概可以划分为如下几块:
head页面头部:存放一个运用的公共信息:logo等,如果是网站可能是最上面的一块.
menu页面菜单:放置一个运用中需要使用的菜单,或者在每一个页面都使用的连接.
footer页面尾部:如版权信息等.
body页面主题内容:每个页面相对独立的内容.
如果按上面的划分那对每一个页面我们只要写body里面的内容,其他的就可以共享重用.
如果大多数页面的布局基本相同我们甚至可以使用一个jsp文件根据不同的参数调用不同的body.

二:Tiles配置和基本配置文件介绍
Tiles有一个配置文件:tiles-defs.xml
tiles-defs.xml定义了每一个页面的组成元素和形式。
下面我将说明如下所示的一个tiles-defs.xml文件
tiles-defs.xml
-----------------------------------------------

<tiles-definitions>
<!--定义/layouts/classicLayout.jsp的组成名称为site.mainLayout-->
<!--后面将附/layouts/classicLayout.jsp的内容-->
<definition name="site.mainLayout" path="/layouts/classicLayout.jsp">
<put name="title" value="Tiles Blank Site" />
<put name="header" value="/tiles/common/header.jsp" />
<put name="menu" value="site.menu.bar" />
<!--menu的组成为site.menu.bar对应的页面-->
<put name="footer" value="/tiles/common/footer.jsp" />
<put name="body" value="/tiles/body.jsp" />
</definition>
<!--定义site.index.page,继承site.mainLayout-->
<definition name="site.index.page" extends="site.mainLayout" >
<put name="title" value="Tiles Blank Site Index" />
<put name="body" value="/tiles/body.jsp" />
<!--以上两个元素将替换site.mainLayout中的元素-->
</definition>

<definition name="site.menu.bar" path="/layouts/vboxLayout.jsp" >
<putList name="list" >
<add value="site.menu.links" />
<add value="site.menu.documentation" />
</putList>
</definition>
</tiles-definitions>

 附:/layouts/classicLayout.jsp
--------------------------------

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

<body bgcolor="#ffffff" text="#000000" link="#023264" alink="#023264" vlink="#023264">
<table border="0" width="100%" cellspacing="5">
<tr>
<td colspan="2"><tiles:insert attribute="header" /></td>
</tr>
<tr>
<td width="140" valign="top">
<tiles:insert attribute='menu'/>
</td>
<td valign="top" align="left">
<tiles:insert attribute='body' />
</td>
</tr>
<tr>
<td colspan="2">
<tiles:insert attribute="footer" />
</td>
</tr>
</table>
</body>
</html>

 在web.xml里面配置tiles,配置完后对应struts action servlet的配置如下:
web.xml
-----------------

<!-- Action Servlet Configuration -->
<servlet>
<servlet-name>action</servlet-name>
<!-- Specify servlet class to use:
- Struts1.0.x: ActionComponentServlet
- Struts1.1: ActionServlet
- no Struts: TilesServlet
--> 
<servlet-class>org.apache.struts.action.ActionServlet</servlet-class>

<!-- Tiles Servlet parameter 
Specify configuration file names. There can be several comma 
separated file names
--> 
<init-param>
<param-name>definitions-config</param-name>
<param-value>/WEB-INF/tiles-defs.xml</param-value>
</init-param>

<!-- Tiles Servlet parameter 
Specify Tiles debug level.
O : no debug information
1 : debug information
2 : more debug information
--> 
<init-param>
<param-name>definitions-debug</param-name>
<param-value>1</param-value>
</init-param>

<!-- Tiles Servlet parameter 
Specify Digester debug level. This value is passed to Digester
O : no debug information
1 : debug information
2 : more debug information
--> 
<init-param>
<param-name>definitions-parser-details</param-name>
<param-value>0</param-value>
</init-param>

<!-- Tiles Servlet parameter 
Specify if xml parser should validate the Tiles configuration file.
true : validate. DTD should be specified in file header.
false : no validation
--> 
<init-param>
<param-name>definitions-parser-validate</param-name>
<param-value>true</param-value>
</init-param>

<!-- Struts configuration, if Struts is used -->
<init-param>
<param-name>config</param-name>
<param-value>/WEB-INF/struts-config.xml</param-value>
</init-param>
<init-param>
<param-name>validate</param-name>
<param-value>true</param-value>
</init-param>
<init-param>
<param-name>debug</param-name>
<param-value>2</param-value>
</init-param>
<init-param>
<param-name>detail</param-name>
<param-value>2</param-value>
</init-param>

<load-on-startup>2</load-on-startup>
</servlet>

 三:使用Tiles
如果已经配置好tiels-defs.xml,接下来就可以在jsp文件中使用这些定义了。
有如下的方式使用tiles
3.1:
<tiles:insert definition="site.mainLayout" flush="true" />
插入site.mainLayout标记的一页

3.2:

<tiles:insert template="/tutorial/basic/myFramesetLayout.jsp" >
<tiles:put name="title" content="My first frameset page" direct="true" />
<tiles:put name="header" content="/tutorial/common/header.jsp" direct="true"/>
<tiles:put name="footer" content="/tutorial/common/footer.jsp" direct="true"/>
<tiles:put name="menu" content="/tutorial/basic/menu.jsp" direct="true"/>
<tiles:put name="body" content="/tutorial/basic/helloBody.jsp" direct="true"/>
</tiles:insert>

 /tutorial/basic/myFramesetLayout.jsp
---------------------------------

<html>
<head>
<title><tiles:get name="title"/></title>
</head>

<frameset rows="73, *, 73">
<frame src="<%=request.getContextPath()%><tiles:get name="header" />" name="header" >
<frame src="<%=request.getContextPath()%><tiles:get name="body" />" name="body" >
<frame src="<%=request.getContextPath()%><tiles:get name="footer" />" name="footer" >
</frameset>

</html>

插入/tutorial/basic/myFramesetLayout.jsp
并把title的值设定为:My first frameset page
header设定为/tutorial/common/header.jsp


四:后记
Tiles的使用在他的文档里面写的比较详细。以上是一些简单和基本的使用。具体的文档可以看
Struts里面的一个tiles-documentation.war的包。但即使是这个包也不是很全。可以通过上的的
连接到作者的主页上去找。
个人觉得使用Tiles在做企业运用的时候可能不如在做网站那样更能体现优越性。但在系统开始
设计的时候考虑并规划好整个UI,那在修改和维护的时候将节省不少的工作量,因为通常UI的确定
在代码编写结束和完成,所有尽可能的使用多个子页面构成一个页面,后面的美化和维护就比直接
维护一个很大的页面容易。

 

 

 

 

 

 

 

 

 

 

 

 

分享到:
评论

相关推荐

    struts中tiles标签简介

    在Web开发领域,尤其在使用Struts框架时,为了提高代码复用性及页面布局的灵活性,开发者经常使用到一个非常有用的工具——Tiles框架。Tiles框架允许我们通过组合可复用的组件来构建网页。这种组件化的思想不仅使得...

    SpringMVC使用tiles

    1. **Tiles简介** Tiles框架的核心概念是“定义-使用”模式。定义是指创建一个页面模板,其中包含可替换的部分(称为“部件”),然后在实际页面中使用这些模板和部件。这样可以方便地管理页面结构,使多个页面共享...

    spring tiles

    #### 一、Spring与Tiles框架简介 **Spring**是一个轻量级的Java开发框架,主要用于简化企业级应用的开发过程。它提供了强大的依赖注入(DI)功能,使得开发者能够轻松地管理和组织应用程序中的各种组件。 **Tiles*...

    Struts2 tiles操作例子

    Struts2与tiles插件简介 Struts2的核心优势在于其灵活性和可扩展性,它允许开发者使用各种不同的技术来构建Web应用,如JSP、Freemarker等。tiles插件通过提供一种机制来定义和管理页面的布局结构,使得页面设计...

    apache tiles3.0

    一、Apache Tiles 3.0简介 Apache Tiles的主要目标是通过定义和重用页面模板来简化Web应用的视图层开发。Tiles 3.0在此基础上进行了优化,提高了性能和易用性,同时保持了与早期版本的兼容性。这个版本引入了一些新...

    tiles 简明教程

    #### 16.1 Tiles框架简介 **Tiles框架**是建立在JSP的`include`指令基础上的一个扩展性更强的解决方案,其核心特性包括: - **创建可重用的模板**:允许开发者定义一系列通用的布局模板,并将这些模板应用于多个...

    objTo3d-tiles.rar

    本篇文章将详细探讨一个名为“objTo3d-tiles”的工具,该工具能够将多种格式的3D模型转换为3D Tiles格式,以供Cesium使用。 一、3D Tiles格式简介 3D Tiles是一种基于云计算的分块结构,通过将大规模3D地理空间...

    Tiles框架.pdf

    Tiles框架简介 在Web应用程序开发过程中,为了确保网站的一致性和用户体验,经常需要让所有网页保持相同的外观,例如统一的布局、页头(Header)、页尾(Footer)和菜单(Menu)。这种需求在传统的JSP页面中往往...

    first_struts_tiles_tutorial.pdf

    - **Struts 2 简介**:Struts 2 是一款基于 Java 的企业级应用框架,它支持多种插件扩展,包括 Tiles。 - **集成 Tiles**:在 Struts 2 中使用 Tiles 需要在 `struts.xml` 文件中配置 Tiles 插件。 - **示例**: `...

    Live Tiles 与消息推送

    其中大尺寸的 Live Tiles 主要支持第一方应用程序使用,为用户提供更丰富的信息展示空间。 每个 Tile 都具有一套预定义的数据属性,这些属性与界面元素相对应。例如,“标题”、“计数”、“背景图像”等。这些属性...

    cesiumjs瓦片数据 3dtiles

    在CesiumJS中使用3D Tiles数据非常简单直观。只需要通过`Cesium3DTileset`类实例化一个对象,并指定3D Tiles数据源即可实现加载: ```javascript var tileset = new Cesium.Cesium3DTileset({ url : 'path/to/your...

    Struts2 标签使用简介

    这篇简介将深入探讨Struts2中的标签使用。 一、Struts2标签库概述 Struts2的标签库是由一系列预定义的JSP标签组成的,这些标签用于处理表单、显示数据、控制流程等任务,减少了开发者编写大量Java脚本和HTML代码的...

    three-tiles:用 libGDX 制作的名为 Three Tiles 的简单游戏

    《使用libGDX框架开发Three Tiles游戏》 libGDX是一个强大的开源游戏开发框架,它支持多平台,包括Android、iOS、HTML5以及桌面应用。本项目“three-tiles”是一个基于libGDX构建的简单游戏,名为“Three Tiles”,...

    tiles2-plugin:自动从code.google.comptiles2-plugin导出

    - `README.md`:项目简介和使用指南。 通过深入研究这些文件,开发者可以了解插件的工作原理、如何安装和使用,以及如何将其整合到自己的项目中。对于使用Tiles2框架的Java开发者来说,这个插件可能是一个宝贵的...

    MODIS数据的简介和下载.pdf

    MODIS数据,即中分辨率成像光谱辐射计数据,是目前全球遥感领域的重要数据源之一,主要来源于MODIS传感器,该传感器搭载在Terra和Aqua卫星上。MODIS传感器的全称为中分辨率成像光谱仪(Moderate-resolution Imaging ...

    3D模型研究

    - **格式转换**:使用专门的工具将PLY文件转换为3D Tiles格式。 具体操作步骤如下: - **下载并配置Docker环境**:根据GitHub链接([https://github.com/kiselev-dv/osm-cesium-3d-tiles]...

    Spring API

    1. 简介 1.1. 概览 1.1.1. 使用场景 2. Spring 2.0和 2.5的新特性 2.1. 简介 2.2. 控制反转(IoC)容器 2.2.1. 新的bean作用域 2.2.2. 更简单的XML配置 2.2.3. 可扩展的XML编写 2.2.4. Annotation(注解)驱动...

    VI规范手册 - 微软.pdf

    本文档是Microsoft视觉身份指导手册的简介,旨在帮助Microsoft员工和合作伙伴了解Microsoft的视觉身份系统,并指导如何正确地使用视觉身份元素来表达Microsoft品牌。 一、Microsoft视觉身份系统 Microsoft视觉身份...

    Spring中文帮助文档

    2.1. 简介 2.2. 控制反转(IoC)容器 2.2.1. 新的bean作用域 2.2.2. 更简单的XML配置 2.2.3. 可扩展的XML编写 2.2.4. Annotation(注解)驱动配置 2.2.5. 在classpath中自动搜索组件 2.3. 面向切面编程(AOP) ...

    【cocos2d-html5】 如何使用cocos2d-html5 制作基于tile地图的游戏教程:第一部分

    1. **Cocos2d-HTML5简介**: Cocos2d-HTML5是一个强大的2D游戏开发框架,它提供了一系列工具和API,使开发者能够快速构建交互式游戏。该框架基于WebGL,因此游戏可以在现代浏览器上流畅运行,无需插件。 2. **Tile...

Global site tag (gtag.js) - Google Analytics