SpringMVC整合Tiles框架

Tiles组件

tiles-iconfig.xml

Tiles是一个JSP布局框架。

Tiles框架为创建Web页面提供了一种模板机制,它能将网页的布局和内容分离。它用模板定义网页布局,每个页面模板都是一个简单的 JSP 页,它定义了一些由占位符组成的外形,以放置内容。执行时,Tiles 将会用相应的内容来替换占位符,因此,创建整个页面即形成布局。Tiles框架是建立在JSP的include指令基础上的,但它提供了比JSP的include指令更强大的功能。Tiles框架具有如下特性:

1.         创建可重用的模板

2.         动态构建和装载页面

3.         定义可重用的Tiles组件

4.         支持国际化。

接下来就介绍Tiles框架的基本使用。

<tiles-definitions>标签内主要的子节点就是<definition>标签,这个标签属性如下:

属性

名称

是否必须

值必须

值类型

说明

name

true

true

java.lang.String

指定将要创建的一个definition bean的访问名称。这个必须有的。

template

false

true

java.lang.String

哪一个文件是模板文件,这个模板文件后面会介绍。

role

false

true

java.lang.String

如果配置了这个值的话,需要role的值相等,这个definition才被有效访问,这个功能我没有深究,也不推荐使用,建议大家建立自己更完善的权限控制管理。当然欢迎朋友们完善role应用的示例,tiles自带role的示例,有兴趣的人去读一下就明白了。

extends

false

true

java.lang.String

继承哪一个definition,值是你要继承的definition的name的值。高使用率的属性。

preparer

false

true

java.lang.String

呵,我没使用,如果你要使用的话,要写一个实现他的Prepare接口的类,作用就是在展现你定义的页面前会先执行你的prepare。

应用程序布局

我们的目标是我们Spring3HelloWorld应用程序添加页眉,页脚和菜单。以下将是相同的布局。

所需JAR包

上述表中突出显示的jar文件要添加新的Tiles集成项目。

在Spring mvc 中配置Tiles框架

要配置Tiles,在spring-servlet.xml中配置一个TilesConfig的<bean>。打开spring-servlet.xml,并添加下面的代码<beans></beans>标记之间。

WEB-INF/spring-servlet.xml:
1 <bean id="viewResolver" 
2     class="org.springframework.web.servlet.view.UrlBasedViewResolver"> 
3     <property name="viewClass"> 
4         <value> 
5             org.springframework.web.servlet.view.tiles2.TilesView 
6         </value> 
7     </property> 
8 </bean> 
9 <bean id="tilesConfigurer" 
10     class="org.springframework.web.servlet.view.tiles2.TilesConfigurer"> 
11     <property name="definitions"> 
12         <list> 
13             <value>/WEB-INF/tiles.xml</value> 
14         </list> 
15     </property> 
16 </bean>

通过上面定义的参数.在WEB-INF中写一个tiles的配置文件"tiles.xml"这个xml为我们的web项目定义Tiles

WEB-INF/tiles.xml:

1 <?xml version="1.0" encoding="UTF-8" ?> 
2 <!DOCTYPE tiles-definitions PUBLIC 
3        "-//Apache Software Foundation//DTD Tiles Configuration 2.0//EN" 
4        "http://tiles.apache.org/dtds/tiles-config_2_0.dtd"> 
5 <tiles-definitions> 
6     <definition name="base.definition" 
7         template="/WEB-INF/jsp/layout.jsp"> 
8         <put-attribute name="title" value="" /> 
9         <put-attribute name="header" value="/WEB-INF/jsp/header.jsp" /> 
10         <put-attribute name="menu" value="/WEB-INF/jsp/menu.jsp" /> 
11         <put-attribute name="body" value="" /> 
12         <put-attribute name="footer" value="/WEB-INF/jsp/footer.jsp" /> 
13     </definition> 
14   
15     <definition name="contact" extends="base.definition"> 
16         <put-attribute name="title" value="Contact Manager" /> 
17         <put-attribute name="body" value="/WEB-INF/jsp/contact.jsp" /> 
18     </definition> 
19   
20 </tiles-definitions>

在这里,我们有tiles.xml定义模板base.definition。该布局包含的属性,如头,标题,主体,菜单和页脚。然后扩展和布局的新关联页面。我们覆盖默认的布局改变Body和Title的内容。

创建我们的JSP文件

我们写一个layout.jsp作为我们web项目的布局页面然后引入相应的页面

WEB-INF/jsp/layout.jsp
1 <%@ taglib uri="http://tiles.apache.org/tags-tiles" prefix="tiles"%> 
2 <!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" 
3 "http://www.w3.org/TR/html4/loose.dtd"> 
4 <html> 
5 <head> 
6 <meta http-equiv="Content-Type" content="text/html; charset=UTF-8"> 
7 <title><tiles:insertAttribute name="title" ignore="true" /></title> 
8 </head> 
9 <body> 
10 <table border="1" cellpadding="2" cellspacing="2" align="center"> 
11     <tr> 
12         <td height="30" colspan="2"><tiles:insertAttribute name="header" /> 
13         </td> 
14     </tr> 
15     <tr> 
16         <td height="250"><tiles:insertAttribute name="menu" /></td> 
17         <td width="350"><tiles:insertAttribute name="body" /></td> 
18     </tr> 
19     <tr> 
20         <td height="30" colspan="2"><tiles:insertAttribute name="footer" /> 
21         </td> 
22     </tr> 
23 </table> 
24 </body> 
25 </html> 
 
WEB-INF/jsp/header.jsp
26 <h1>Header</h1> 
WEB-INF/jsp/menu.jsp
27 <span style="font-size: 14px;"><p>Menu</p></span> 
WEB-INF/jsp/footer.jsp
<span style="font-size: 14px;"><p>Copyright <code class="xml plain">©</code>Zemo.com</p></span>
所有工作准备就绪部署就行了

SpringMVC整合Tiles框架的更多相关文章

  1. Springmvc整合tiles框架简单入门示例(maven)

    Springmvc整合tiles框架简单入门示例(maven) 本教程基于Springmvc,spring mvc和maven怎么弄就不具体说了,这边就只简单说tiles框架的整合. 先贴上源码(免积 ...

  2. springmvc整合mybatis框架源码 bootstrap

    A集成代码生成器 [正反双向(单表.主表.明细表.树形表,开发利器)+快速构建表单 下载地址    ; freemaker模版技术 ,0个代码不用写,生成完整的一个模块,带页面.建表sql脚本,处理类 ...

  3. springmvc整合mybatis框架源码 bootstrap html5 mysql oracle maven SSM

    A 调用摄像头拍照,自定义裁剪编辑头像 [新录针对本系统的视频教程,手把手教开发一个模块,快速掌握本系统]B 集成代码生成器 [正反双向](单表.主表.明细表.树形表,开发利器)+快速构建表单;  技 ...

  4. SSM框架-----------SpringMVC+Spring+Mybatis框架整合详细教程

    1.基本概念 1.1.Spring Spring是一个开源框架,Spring是于2003 年兴起的一个轻量级的Java 开发框架,由Rod Johnson 在其著作Expert One-On-One  ...

  5. SpringMVC整合Shiro权限框架

    尊重原创:http://blog.csdn.net/donggua3694857/article/details/52157313 最近在学习Shiro,首先非常感谢开涛大神的<跟我学Shiro ...

  6. Spring+SpringMVC+MyBatis+Maven框架整合

    本文记录了Spring+SpringMVC+MyBatis+Maven框架整合的记录,主要记录以下几点 一.Maven需要引入的jar包 二.Spring与SpringMVC的配置分离 三.Sprin ...

  7. springmvc+spring3+hibernate4框架简单整合,简单实现增删改查功能

    转自:https://blog.csdn.net/thinkingcao/article/details/52472252 C 所用到的jar包     数据库表 数据库表就不用教大家了,一张表,很简 ...

  8. SpringMVC整合Shiro,Shiro是一个强大易用的Java安全框架,提供了认证、授权、加密和会话管理等功能

    SpringMVC整合Shiro,Shiro是一个强大易用的Java安全框架,提供了认证.授权.加密和会话管理等功能. 第一步:配置web.xml <!-- 配置Shiro过滤器,先让Shiro ...

  9. 整合SSM框架必备基础—SpringMVC(下)

    在上一篇文章<整合SSM框架必备基础-SpringMVC(上)>中,胖达介绍了关于SpringMVC的诞生.优势以及执行流程等理论知识点,这篇文章打算在实操中加深一下对SpringMVC的 ...

随机推荐

  1. Scrum站立会议----11月4日

    小组名称:nice! 组长:李权 成员:于淼  刘芳芳韩媛媛 宫丽君 时间:2016.11.4    12:00--12:30 地点:传媒西楼220室 代码地址:Https:  https://git ...

  2. Javascript动态加载Html元素到页面Dom文档结构时执行顺序的不同

    我们有时会通过ajax动态获取一段Html代码,并且将这段代码通过javascript放到页面的Dom结构中去. 而很多时候通过ajax动态获取的Html代码中也包含javascript代码,有一点需 ...

  3. html规范整体结构

    <!DOCTYPE html><html lang="zh"><head> <meta charset="utf-8" ...

  4. exe文件打开方式(恢复EXE文件关联)

    文件关联损坏常常是计算机病毒造成的,目前网络上有很多相关修复工具,相对来说,System Repair Engineer 支持的修复格式是比较齐全的,这个工具可以在http://www.kztechs ...

  5. 非常好!!!【从头开始写操作系统系列】实现一个-GDT(1)【转】

    转自:http://blog.csdn.net/luoyhang003/article/details/47338019 权声明:本文为博主原创文章,未经博主允许不得转载.(文章来源:http://b ...

  6. 图解 交集(join)和 合并(union)

    假设我们有两张表. Table A 是左边的表. Table B 是右边的表. 其各有四条记录,其中有两条记录是相同的,如下所示: id name       id  name 1  Pirate   ...

  7. 中颖4位MCU的减法汇编指令

    1, SUB M 执行动作: M - A -> A, 如果M-A的过程中没有产生借位,则CY= 1,如果产生了借位,则CY= 0. 其中,A为累加器. 2, SBI M, I 执行动作:M - ...

  8. PHP获取不了React Native Fecth参数的解决办法代码是怎样?

    fetch('https://mywebsite.com/endpoint/', { method: 'POST',headers: {'Accept': 'application/json','Co ...

  9. PHP无限级分类-递归(不推荐)

    [http://www.helloweba.com/view-blog-204.html] 在一些复杂的系统中,要求对信息栏目进行无限级的分类,以增强系统的灵活性.那么PHP是如何实现无限级分类的呢? ...

  10. 搭建HTTP Live Streaming直播系统

    最近,需要将苹果的HTTP Live Streaming系统搭建起来.完全没有头绪,故第一步就是学习. 一.学习资料 官网资料 1. http://developer.apple.com/resour ...