问题:
Web产品开发中大家会面临着同一个问题----页面中大部分都是固定不变的,变化的只有内容部分,也可以说每个产品都有一定的风格或者是使用了几类模板。 遇到了问题就要想办法解决!相信大家也想找一个方法,提高Web代码的复用性和可维护性。下面介绍一下我们的解决方案。
解决方案:
Apache Tiles 框架来创建可重用的表示组件 ,可以划分表示层以更好地重用布局。
最早的Tiles是组装在Struts1.1里面的,主要目的是为了将复数的jsp页面作为一个的页面的部分机能,然后用来组合成一个最终表示用页面用的,这样的话,便于对页面的各个机能的变更及维护。 Tiles使得struts在页面的处理方面多了一种选择。并且更容易实现代码的重用。 (百度百科)
相关内容(具体查看ppt):
- Tile
- Template
- Attribute
- Definition
- Nesting and Extending Definitions
- List Attributes
- Wildcard support
- View Preparers
- Others
使用方法(具体代码可参考附件中tiles-demo):
开发工具、插件、开源软件
Eclipse 、Maven、M2Eclipse、JDK1.6(必须1.5or以上)、Tiles2.2、Spring、SpringMVC、slf4j、jstl、jetty
首先新建maven项目,网上有很多介绍,这里省略。
在POM中添加必要的jar依赖,包括Tiles2.2、Spring、slf4j、jstl和servlet(因为用jetty)。具体可以参考下面的附件。
集成spring和springmvc,省略(原因同上,网上介绍的太多啦)。
添加Tiles配置文件,默认在WEB-INF下,格式比较简单。
1)定义模板页面
<%@ taglib uri="http://tiles.apache.org/tags-tiles" prefix="tiles"%>
<html>
<head>
<title><tiles:getAsString name="title" /></title>
<meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
</head>
<body>
<table style="margin: auto; border: 1px; border-style: solid; border-color: #ccc; width: 900px;">
<tr style="height: 100px; background-color: #555;">
<td colspan="2">
<tiles:getAsString name="head" />
</td>
</tr>
<tr>
<td style="width: 200px; height: 500px; background-color: #666;">
<tiles:getAsString name="menu" />
</td>
<td>
<tiles:insertAttribute name="content"></tiles:insertAttribute>
</td>
</tr>
<tr style="height: 50px; background-color: #333;">
<td colspan="2">
<tiles:getAsString name="footer" />
</td>
</tr>
</table>
</body>
</html>
2)在 tiles.xml 中定义和配置模板
<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE tiles-definitions PUBLIC
"-//Apache Software Foundation//DTD Tiles Configuration 2.1//EN"
"http://tiles.apache.org/dtds/tiles-config_2_1.dtd">
<tiles-definitions>
<definition name="base" template="/WEB-INF/pages/string/layout.jsp" >
<put-attribute name="title" value="hello tiles"></put-attribute>
<put-attribute name="head" value="head"></put-attribute>
<put-attribute name="menu" value="menu"></put-attribute>
<put-attribute name="footer" value="footer"></put-attribute>
</definition>
</tiles-definitions>
3)集成Spring
将springmvc与tiles集成,主要是是在mvc-servlet中添加配置,如下:
指定tiles配置文件位置(代码如下)
<bean id="tilesConfigurer" class="org.springframework.web.servlet.view.tiles2.TilesConfigurer">
<property name="definitions">
<list>
<value>/WEB-INF/tiles.xml</value>
</list>
</property>
</bean>
配置tiles视图解析(代码如下)
<bean id="viewResolver" class="org.springframework.web.servlet.view.UrlBasedViewResolver">
<property name="viewClass">
<value>
org.springframework.web.servlet.view.tiles2.TilesView
</value>
</property>
</bean>
<bean id="tilesResolver" class="org.springframework.web.servlet.view.tiles2.TilesViewResolver">
<property name="viewClass" value="org.springframework.web.servlet.view.tiles2.TilesView" />
<property name="order" value="1" />
<property name="viewNames">
<list>
<value>*</value>
</list>
</property>
</bean>
配置jstl视图解析(代码如下)
<bean id="filenameController" class="org.springframework.web.servlet.mvc.UrlFilenameViewController" />
<bean id="jstlViewResolver" class="org.springframework.web.servlet.view.InternalResourceViewResolver">
<property name="viewClass" value="org.springframework.web.servlet.view.JstlView" />
<property name="prefix" value="/WEB-INF/pages/" />
<property name="suffix" value=".jsp" />
<property name="order" value="2" />
</bean>
完成以上步骤基本就可以了
参考资料:
http://tiles.apache.org/2.2/framework/tutorial/index.html
Warning! Tiles users that use Tiles 2.1.1 or 2.1.0 version should not install it in a production environment, due to a discovered security problem. Upgrade Tiles.
Tiles 2.0.x is not involved in this security bug.
Tiles Runtime Environment
a Java Runtime Environment following the Java SE 5.0 specifications;
a servlet container that supports Servlet 2.4 (or above) and JSP 2.0 (or above).
分享到:
相关推荐
IEEE 文章,详细介绍HEVC的Tile相关feature,以及所做的一些试验数据与对比。
主要给大家介绍了关于Spring mvc整合tiles框架的简单入门教程(maven),文中通过示例代码介绍的非常详细,对大家具有一定的参考学习价值,需要的朋友可以参考借鉴,下面来一起看看详细的介绍吧。
本文档介绍了3Dtiles的规范,3Dtiles是用于流式传输大量离散的3D地理空间数据集的开放标准。
香港倾斜摄影模型(OSGB、OBJ、3D_tiles)等格式的引导文件,从政府官网获取的数据。这是引导文件,里面介绍了每一块数据的边界范围和每种格式的下载地址,还有三维预览方法等。例如:{ "properties" : { ...
过程介绍在我的Csdn Blog
介绍这将总共创建3个容器。 postgis-这是运行postgres数据库的容器。 实际的数据库文件将映射到容器外部,如下面进一步说明。 gisapi-这是NodeJS应用程序,实际上为矢量瓦片/ PBF服务。 它基于 ,而则是从派生并稍加...
介绍 基本瓷砖渲染的现场演示,请,和矢量砖的谷歌地图上的演示是 截图来自基本的瓷砖渲染演示... 以及Google Map演示上的矢量图块的屏幕截图... 与矢量图块的其他实现不同,此渲染器并非设计用于渲染功能齐全的...
c-Tiles16 变量的色彩设计介绍在Sass / Less / Stylus样式表的顶部声明两个颜色变量是一回事。 在您的设计中以直观,有意义的方式使用它们是另一回事。 这就是c-Tiles16来提供帮助的地方。 有两个部分: 命名为A的...
该项目旨在介绍如何创建Spring MVC + Bootstrap + Tiles应用程序 图书馆 SpringMVC Apache Tiles 3.0.5 Bootstrap 3.2.0 jQuery 1.11.0 Log4j 要求 版本8+ 如何运行应用程序 在Windows上 # # Build application...
struts-taglib-1.3.8.jar struts-taglib-1.3.8.jar
程序介绍: Windows Phone Blog Menu是一个Silverlight导航控件,看起来像Windows Phone 7。 控件中的tiles链接到web站点在你的博客中使用这个控件可以表达你对WP7的喜爱。 Windows Phone Blog Menu is a ...
HTML5钢琴瓷砖项目简短的介绍在浏览器中运行的深色主题,深色主题“钢琴瓷砖”克隆,其功能和外观都得到了简化,从本质上试图类似于原始应用程序。资料来源我使用和库来制作它,并且我从原始apk中获得了钢琴声音样本...
本书通过5个完整的项目开发实施,系统地介绍了在...第2章至第6章针对不同的应用背景编排实例,将Sturts技术的知识点和技巧分散在具体的项目开发中,使读者在实践中加深理解,从而掌握Struts技术及Tiles等高级应用。
本书通过5个完整的项目开发实施,系统地介绍了在...第2章至第6章针对不同的应用背景编排实例,将Sturts技术的知识点和技巧分散在具体的项目开发中,使读者在实践中加深理解,从而掌握Struts技术及Tiles等高级应用。
本书通过5个完整的项目开发实施,系统地介绍了在...第2章至第6章针对不同的应用背景编排实例,将Sturts技术的知识点和技巧分散在具体的项目开发中,使读者在实践中加深理解,从而掌握Struts技术及Tiles等高级应用。
第12章到第16章结合具体的Struts应用实例,详细介绍了Struts的标签库以及Tiles框架的使用方法。第17章和第18章介绍如何采用EJB和Web服务来实现Struts框架的模型。第19章到第21章介绍了如何采用第三方软件,如Apache ...
第12章到第16章结合具体的Struts应用实例,详细介绍了Struts的标签库以及Tiles框架的使用方法。第17章和第18章介绍如何采用EJB和Web服务来实现Struts框架的模型。第19章到第21章介绍了如何采用第三方软件,如Apache ...
第12章到第16章结合具体的Struts应用实例,详细介绍了Struts的标签库以及Tiles框架的使用方法。第17章和第18章介绍如何采用EJB和Web服务来实现Struts框架的模型。第19章到第21章介绍了如何采用第三方软件,如Apache ...
第12章到第16章结合具体的Struts应用实例,详细介绍了Struts的标签库以及Tiles框架的使用方法。第17章和第18章介绍如何采用EJB和Web服务来实现Struts框架的模型。第19章到第21章介绍了如何采用第三方软件,如Apache ...
第12章到第16章结合具体的Struts应用实例,详细介绍了Struts的标签库以及Tiles框架的使用方法。第17章和第18章介绍如何采用EJB和Web服务来实现Struts框架的模型。第19章到第21章介绍了如何采用第三方软件,如Apache ...