使用Apache Tiles视图定义布局

Tiles是一个免费的开源模板Java应用程序的框架。基于复合模式简化的用户界面的构建。对于复杂的网站仍是最简单、最优雅的方式与任何MVC技术一起工作。Struts2对Tiles提供了支持,如今Tiles发展已有13个年头,成为Apache的一个独立项目,我们可以单独使用Tiles来构建用户界面布局。

Tiles项目:http://tiles.apache.org/index.html

Tiles的配置DTD定义:http://tiles.apache.org/framework/tiles-core/dtddoc/index.html

本文主要通过构建一个简单的页面布局来认识Apache Tiles3.x(由于Tiles2.x和Tiles3.x存在较大差异)。

本人的目录结构如下:

1.准备工作

1.1安装Apache Tiles3.x依赖的Jar

  1. <dependency>
  2. <groupId>org.apache.tiles</groupId>
  3. <artifactId>tiles-extras</artifactId>
  4. <version>3.0.5</version>
  5. </dependency>
  6. <dependency>
  7. <groupId>org.apache.tiles</groupId>
  8. <artifactId>tiles-servlet</artifactId>
  9. <version>3.0.5</version>
  10. </dependency>
  11. <dependency>
  12. <groupId>org.apache.tiles</groupId>
  13. <artifactId>tiles-jsp</artifactId>
  14. <version>3.0.5</version>
  15. </dependency>

注意:这里使用了Apache3.x完整包依赖。

1.3配置web.xml

​ 在web.xml中添加Tiles监听器

  1. <listener>
  2. <listener-class>org.apache.tiles.extras.complete.CompleteAutoloadTilesListener</listener-class>
  3. </listener>

关于Tiles的监听器可以自定义实现,参见:http://tiles.apache.org/framework/config-reference.html

2.分析界面组成,构建布局文件

假设本案例中的页面构成如图:

分析界面布局,找不通用部分,特殊部分。 在webapp下创建layout文件夹放在布局文件,snippet文件夹放置公共部分。

通过分析,将布局切割为header,body,footer,并且将HTML页面中的meta,script公共部分抽取出来。

/snippet/meta.jsp

  1. <%@ page language="java" contentType="text/html; charset=UTF-8"
  2. pageEncoding="UTF-8"%>
  3. <meta http-equiv="Content-Type" content="text/html; charset=UTF-8">

/snippet/script.jsp

  1. <%@ page language="java" contentType="text/html; charset=UTF-8"
  2. pageEncoding="UTF-8"%>
  3. <style>
  4. div {
  5. width: 480px;
  6. height: 80px;
  7. background: silver;
  8. }
  9. #body {
  10. background: lime;
  11. }
  12. </style>
  13. <script type="text/javascript">
  14. document.writeln("这句话是由JavaScript写入页面的。");
  15. </script>

/snippet/header.jsp

  1. <%@ page language="java" contentType="text/html; charset=UTF-8"
  2. pageEncoding="UTF-8"%>
  3. <h3>
  4. 这是头部
  5. </h3>

/snippet/footer.jsp

  1. <%@ page language="java" contentType="text/html; charset=UTF-8"
  2. pageEncoding="UTF-8"%>
  3. <h3>这是页脚</h3>

/snippet/index_body.jsp

  1. <%@ page language="java" contentType="text/html; charset=UTF-8"
  2. pageEncoding="UTF-8"%>
  3. <pre>
  4. 这是页面的主体部分
  5. </pre>

通过上面的公共部分和主体,构建一个布局文件如下:

/layout/index_layout.jsp

  1. <%@ page language="java" contentType="text/html; charset=UTF-8"
  2. pageEncoding="UTF-8"%>
  3. <%@ taglib uri="http://java.sun.com/jsp/jstl/core" prefix="c"%>
  4. <%@ taglib uri="http://tiles.apache.org/tags-tiles" prefix="tiles"%>
  5. <!DOCTYPE html>
  6. <html>
  7. <head>
  8. <tiles:insertAttribute name="meta" />
  9. <title><tiles:insertAttribute name="title" /></title>
  10. <tiles:insertAttribute name="script" />
  11. </head>
  12. <body>
  13. <div id="header">
  14. <tiles:insertAttribute name="header" />
  15. </div>
  16. <div id="body">
  17. <tiles:insertAttribute name="body" />
  18. </div>
  19. <div id="footer">
  20. <tiles:insertAttribute name="footer" />
  21. </div>
  22. </body>
  23. </html>

3.Tiles的复合布局定义

Tiles是通过在xml文件中配置definition进行页面公共部分的重用,页面布局的组合。

/WEB-INF/tiles-defs.xml 定义好公共部分之后,通过配置definition来组合页面布局。

  1. <?xml version="1.0" encoding="UTF-8" ?>
  2. <!DOCTYPE tiles-definitions PUBLIC "-//Apache Software Foundation//DTD Tiles Configuration 3.0//EN"
  3. "http://tiles.apache.org/dtds/tiles-config_3_0.dtd">
  4. <!-- Definitions for Tiles documentation -->
  5. <tiles-definitions>
  6. <definition name="tiles.base.definition">
  7. <put-attribute name="meta" value="/snippet/meta.jsp" />
  8. <put-attribute name="script" value="/snippet/script.jsp" />
  9. <put-attribute name="header" value="/snippet/header.jsp" />
  10. <put-attribute name="footer" value="/snippet/footer.jsp" />
  11. </definition>
  12. </tiles-definitions>

上面的definition可以说是抽象的,仅仅作为基本的定义抽取了界面中最通用的部分,而且并未指定具体的模版文件(布局文件)。下面通过继承tiles.base.definition来定一个tiles.index.definition其布局模版为/layout/index_layout.jsp。

  1. <definition name="tiles.index.definition" extends="tiles.base.definition"
  2. template="/layout/index_layout.jsp">
  3. <put-attribute name="body" value="/snippet/index_body.jsp" />
  4. </definition>

上面定义tiles.index.definition,新增了body,其值为/snippet/index_body.jsp页面。

4.使用复合布局

​ 到这里已经将页面的布局进行了分割,组合。现在应用definition来构建一个请求响应页面。

/example/index.jsp

  1. <%@ page language="java" contentType="text/html; charset=UTF-8"
  2. pageEncoding="UTF-8"%>
  3. <%@ taglib uri="http://tiles.apache.org/tags-tiles" prefix="tiles"%>
  4. <tiles:insertDefinition name="tiles.index.definition">
  5. <tiles:putAttribute name="title" value="这是一个有Apache Tiles构建的页面布局." />
  6. </tiles:insertDefinition>

5.启动服务器,访问/example/index.jsp

页面展示效果:

接下来看看页面的源代码:

  1. <!DOCTYPE html>
  2. <html>
  3. <head>
  4. <meta http-equiv="Content-Type" content="text/html; charset=UTF-8">
  5. <title>这是一个有Apache Tiles构建的页面布局.</title>
  6. <style>
  7. div {
  8. width: 480px;
  9. height: 80px;
  10. background: silver;
  11. }
  12. #body {
  13. background: lime;
  14. }
  15. </style>
  16. <script type="text/javascript">
  17. document.writeln("这句话是由JavaScript写入页面的。");
  18. </script>
  19. </head>
  20. <body>
  21. <div id="header">
  22. <h3>
  23. 这是头部
  24. </h3>
  25. </div>
  26. <div id="body">
  27. <pre>
  28. 这是页面的主体部分
  29. </pre>
  30. </div>
  31. <div id="footer">
  32. <h3>这是页脚</h3>
  33. </div>
  34. </body>
  35. </html>

该例子中布局index_layout.jsp中body是可变的,title对一个不同的页面有不同的标题设置。在tiles-defx.xml的tiles.index.definition继承了tiles.base.definition,并且添加了其body页面,接着在插入tiles.index.definition的index.jsp页面添加了title。这样做达到的效果是整个站点的header,footer,meta,script抽取到了一个definition,然后通过继承的方式进行扩展,丰富不同的布局的页面组成元素,在具体的响应页面来定义专属该页面的内容。从而达到对页面的布局的控制,公共部分的复用的效果。

6.总结

本文仅仅是一个简单的示例,然而大部分内容被抽取公共部分占去,这样的结果并非意外,对于页面布局的划分,组合,重用才是使用Tiles之前最为繁重和复杂的工作,这些工作能够做的合理,优雅,配置definition自然就轻松多了。

第6章—渲染web视图—使用Apache Tiles视图定义布局的更多相关文章

  1. 第06章-渲染Web视图

    1. 理解视图解析 将控制器中请求处理的逻辑和视图中的渲染实现解耦是Spring MVC的一个重要特性.如果控制器中的方法直接负责产生HTML的话,就很难在不影响请求处理逻辑的前提下,维护和更新视图. ...

  2. 第6章—渲染web视图—SpringMVC+Thymeleaf 处理表单提交

    SpringMVC+Thymeleaf 处理表单提交 thymleaf处理表单提交的方式和jsp有些类似,也有点不同之处,这里操作一个小Demo,并说明: 1.demo的结构图如下所示: pom.xm ...

  3. 第6章—渲染web视图—使用Thymeleaf

    使用Thymeleaf 长期以来,jsp在视图领域有非常重要的地位,随着时间的变迁,出现了一位新的挑战者:Thymeleaf,Thymeleaf是原生的,不依赖于标签库.它能够在接受原始HTML的地方 ...

  4. Spring实战第六章学习笔记————渲染Web视图

    Spring实战第六章学习笔记----渲染Web视图 理解视图解析 在之前所编写的控制器方法都没有直接产生浏览器所需的HTML.这些方法只是将一些数据传入到模型中然后再将模型传递给一个用来渲染的视图. ...

  5. Spring 学习笔记(十)渲染 Web 视图 (Apache Tilesa 和 Thymeleaf)

    使用Apache Tiles视图定义布局 为了在Spring中使用Tiles,需要配置几个bean.我们需要一个TilesConfigurer bean,它会负责定位和加载Tile定义并协调生成Til ...

  6. Spring学习(六)--渲染Web视图

    一.将模型数据渲染为Html 在上一篇文章中,我们所编写的控制器方法都没有直接产生浏览器中渲染所需的HTML.这些方法只是将数据填充到模型中,然后将模型传递给一个用来渲染的视图.这些方法会返回一个St ...

  7. 【Spring】渲染Web视图

    前言 前面学习了编写Web请求的控制器,创建简单的视图,本篇博文讲解控制器完成请求到结果渲染到用户的浏览器的过程. 渲染Web视图 理解视图解析 前面所编写的控制器方法都没有直接产生浏览器中渲染所需要 ...

  8. 渲染Web视图

    Spring MVC定义了一个名为ViewResolver的接口 public interface ViewResolver{ View resolveViewName(String viewName ...

  9. SpringMVC之四:渲染Web视图

    理解视图解析 在前面的例子中,我们看到控制器返回的都是一个逻辑视图的名称,然后把这个逻辑视图名称交给view resolver,然后返回渲染后的 html 页面给 client. 将控制器中请求处理的 ...

随机推荐

  1. Vue组件通信父传方法给子组件调用

    // 父组件中将 :meth='changeCom1' 传入入子组件 , 子组件运行 meth(i) 方法 并给他传参数 ,在父组件可以获取这个参数,并做相应的操作   // 父组件 <temp ...

  2. 如何在eclipse的配置文件里指定jdk路径

    转载自:https://blog.csdn.net/gnail_oug/article/details/51925804:个人做了些小修改. 今天下载了eclipse4.6版本,打开时报Version ...

  3. Google Maps 基础

    创建一个简单的 Google 地图 现在让我们创建一个简单的 Google 地图. 以下是显示了英国伦敦的 Google 地图: <!DOCTYPE html> <html> ...

  4. 201709011工作日记--ART与Dalvik&&静态类与非静态类

    1.ART 与 Dalvik 的优缺点对比 什么是Dalvik:Dalvik是Google公司自己设计用于Android平台的Java虚拟机.dex格式是专为Dalvik应用设计的一种压缩格.Dalv ...

  5. jmap的几个操作要慎用

    JDK中带有了一堆的工具是可以用来查看运行状况,排查问题的,但对于这些工具还是要比较清楚执行后会发生什么,否则有可能会因为执行了一个命令就导致严重故障,重点讲下影响比较大的jmap. 最主要的危险操作 ...

  6. 转:解决windows下eclipse中android项目关联android library project失败问题

    近日,在做一个人人的第三方小项目.打算直接使用renren 的sdk 进行开发.因为renren的sdk是以android library project 形式发布的(关于这种project的内容可以 ...

  7. java中的static(包括类前面修饰的static、方法前面修饰的static、成员变量前面修饰的static)

    static是静态修饰符: 什么叫静态修饰符呢?大家都知道,在程序中任何变量或者代码都是在编译时由系统自动分配内存来存储的,而所谓静态就是指在编译后所分配的内存会一直存在,直到程序退出内存才会释放这个 ...

  8. Chinese Seals

    Emperors used seals to proclaim their decrees to their people, officials used seals to exercise thei ...

  9. Window 64bit环境搭建Web Starter Kit

    最近在学习https://developers.google.com/web/fundamentals/这里的内容,其中就有一部分是安装Web Starter Kit的教程,我总结一下自己的安装过程. ...

  10. Java核心编程快速学习(转载)

    http://www.cnblogs.com/wanliwang01/p/java_core.html Java核心编程部分的基础学习内容就不一一介绍了,本文的重点是JAVA中相对复杂的一些概念,主体 ...