使用Apache Tiles3.x构建界面布局

  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

2

3

4

5

6

7

8

9

10

11

12

13

14

15

<dependency>

            <groupId>org.apache.tiles</groupId>

            <artifactId>tiles-extras</artifactId>

            <version>3.0.5</version>

        </dependency>

        <dependency>

            <groupId>org.apache.tiles</groupId>

            <artifactId>tiles-servlet</artifactId>

            <version>3.0.5</version>

        </dependency>

        <dependency>

            <groupId>org.apache.tiles</groupId>

            <artifactId>tiles-jsp</artifactId>

            <version>3.0.5</version>

        </dependency>

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

   1.2调试环境

     安装jetty-maven-plugin来热部署web应用

     


1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

16

17

<build>

        <finalName>tiles</finalName>

        <plugins>

            <plugin>

                <groupId>org.mortbay.jetty</groupId>

                <artifactId>jetty-maven-plugin</artifactId>

                <version>7.1.6.v20100715</version>

                <configuration>

                    <scanIntervalSeconds>1</scanIntervalSeconds>

                    <reload>automatic</reload>

                    <webAppConfig>

                        <contextPath>/tiles</contextPath>

                    </webAppConfig>

                </configuration>

            </plugin>

        </plugins>

    </build>

      注意:运行mvn jetty:run -Djetty.port=9999 命名,访问http://localhost:9999/tiles 需要额外在Maven的settings.xml文件的插件组中添加插件组标识。

  


1

2

3

4

5

6

7

<pluginGroups>

    <!-- pluginGroup

     | Specifies a further group identifier to use for plugin lookup.

    <pluginGroup>com.your.plugins</pluginGroup>

    -->

    <pluginGroup>org.mortbay.jetty</pluginGroup>

  </pluginGroups>

 

  1.3配置web.xml

     在web.xml中添加Tiles监听器

   


1

2

3

<listener>

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

    </listener>

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

 

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

 

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

  

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

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

 

  •  /snippet/meta.jsp

  


1

2

3

<%@ page language="java" contentType="text/html; charset=UTF-8"

    pageEncoding="UTF-8"%>

<meta http-equiv="Content-Type" content="text/html; charset=UTF-8">

  •  /snippet/script.jsp

 


1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

16

17

<%@ page language="java" contentType="text/html; charset=UTF-8"

    pageEncoding="UTF-8"%>

<style>

div {

    width: 480px;

    height: 80px;

    background: silver;

}

 

#body {

    background: lime;

}

 

</style>

<script type="text/javascript">

    document.writeln("这句话是由JavaScript写入页面的。");

</script>

  • /snippet/header.jsp

1

2

3

4

5

<%@ page language="java" contentType="text/html; charset=UTF-8"

    pageEncoding="UTF-8"%>

<h3>

这是头部

</h3>

  • /snippet/footer.jsp

1

2

3

<%@ page language="java" contentType="text/html; charset=UTF-8"

    pageEncoding="UTF-8"%>

<h3>这是页脚</h3>

 

  •  /snippet/index_body.jsp

 


1

2

3

4

5

<%@ page language="java" contentType="text/html; charset=UTF-8"

    pageEncoding="UTF-8"%>

<pre>

    这是页面的主体部分

</pre>

 

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

 

  • /layout/index_layout.jsp

1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

16

17

18

19

20

21

22

23

<%@ page language="java" contentType="text/html; charset=UTF-8"

    pageEncoding="UTF-8"%>

<%@ taglib uri="http://java.sun.com/jsp/jstl/core" prefix="c"%>

<%@ taglib uri="http://tiles.apache.org/tags-tiles" prefix="tiles"%>

<!DOCTYPE html>

<html>

<head>

<tiles:insertAttribute name="meta" />

<title><tiles:insertAttribute name="title" /></title>

<tiles:insertAttribute name="script" />

</head>

<body>

    <div id="header">

        <tiles:insertAttribute name="header" />

    </div>

    <div id="body">

        <tiles:insertAttribute name="body" />

    </div>

    <div id="footer">

        <tiles:insertAttribute name="footer" />

    </div>

</body>

</html>

 

3.Tiles的复合布局定义

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

 

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

 


1

2

3

4

5

6

7

8

9

10

11

12

13

14

<?xml version="1.0" encoding="UTF-8" ?>

<!DOCTYPE tiles-definitions PUBLIC "-//Apache Software Foundation//DTD Tiles Configuration 3.0//EN" 

"http://tiles.apache.org/dtds/tiles-config_3_0.dtd">

<!-- Definitions for Tiles documentation -->

<tiles-definitions>

 

    <definition name="tiles.base.definition">

        <put-attribute name="meta" value="/snippet/meta.jsp" />

        <put-attribute name="script" value="/snippet/script.jsp" />

        <put-attribute name="header" value="/snippet/header.jsp" />

        <put-attribute name="footer" value="/snippet/footer.jsp" />

    </definition>

 

</tiles-definitions>

 

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

  


1

2

3

4

<definition name="tiles.index.definition" extends="tiles.base.definition"

        template="/layout/index_layout.jsp">

        <put-attribute name="body" value="/snippet/index_body.jsp" />

    </definition>

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

 

4.使用复合布局

  

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

  •  /example/index.jsp

1

2

3

4

5

6

<%@ page language="java" contentType="text/html; charset=UTF-8"

    pageEncoding="UTF-8"%>

<%@ taglib uri="http://tiles.apache.org/tags-tiles" prefix="tiles"%>

<tiles:insertDefinition name="tiles.index.definition">

    <tiles:putAttribute name="title" value="这是一个有Apache Tiles构建的页面布局." />

</tiles:insertDefinition>

 

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

  页面展示效果:

  

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

  


1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

16

17

18

19

20

21

22

23

24

25

26

27

28

29

30

31

32

33

34

35

36

37

38

39

40

41

42

<!DOCTYPE html>

<html>

<head>

 

<meta http-equiv="Content-Type" content="text/html; charset=UTF-8">

<title>这是一个有Apache Tiles构建的页面布局.</title>

 

<style>

div {

    width: 480px;

    height: 80px;

    background: silver;

}

 

#body {

    background: lime;

}

 

</style>

<script type="text/javascript">

    document.writeln("这句话是由JavaScript写入页面的。");

</script>

</head>

<body>

    <div id="header">

         

<h3>

这是头部

</h3>

    </div>

    <div id="body">

         

<pre>

    这是页面的主体部分

</pre>

    </div>

    <div id="footer">

         

<h3>这是页脚</h3>

    </div>

</body>

</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自然就轻松多了。

http://aiilive.blog.51cto.com/1925756/1596059

 接着上一篇:使用Apache Tiles3.x构建界面布局(一)继续构建页面布局。

 

    上一篇示例中已经对页面的公共部分进行了抽取,创建了布局,并且将使用的布局应用的响应页面了。

 

1.定义definition来改变公共部分

    现在有个新变化,响应页面的footer部分需要发生点变化,这个时候仍然可以通过继承的方式来配置一个definition。

 

  • /WEB-INF/tiles-defs.xml 中新增definition

1

2

3

4

<definition name="tiles.override.definition" extends="tiles.index.definition">

        <put-attribute name="footer"

            value="Copy Right &lt;a href='http://aiilive.blog.51cto.com'&gt;野马红尘&lt;/a&gt;"></put-attribute>

    </definition>

 

 1.1创建响应页面/example/index_override.jsp


1

2

3

4

5

6

<%@ page language="java" contentType="text/html; charset=UTF-8"

    pageEncoding="UTF-8"%>

<%@ taglib uri="http://tiles.apache.org/tags-tiles" prefix="tiles"%>

<tiles:insertDefinition name="tiles.override.definition">

    <tiles:putAttribute name="title" value="这是一个有Apache Tiles构建的页面布局." />

</tiles:insertDefinition>

 

 1.2访问:/tiles/example/index_override.jsp

 

  注意:footer部分发生了改变,使用了tiles.override.definition的footer属性。

 

 

 2.响应页面中定义body

  •  /example/home.jsp

 


1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

16

<%@ page language="java" contentType="text/html; charset=UTF-8"

    pageEncoding="UTF-8"%>

<%@ taglib uri="http://tiles.apache.org/tags-tiles" prefix="tiles"%>

<tiles:insertDefinition name="tiles.index.definition">

    <tiles:putAttribute name="title" value="HOME 页面." />

    <tiles:putAttribute name="body">

        <h3>这是HOME页面的body</h3>

        <ul>

            <li>Apache Tiles</li>

            <li>Sitemesh</li>

            <li>Smarty</li>

            <li>Freemarker</li>

            <li>Velocity</li>

        </ul>

    </tiles:putAttribute>

</tiles:insertDefinition>

   

  访问:/tiles/example/home.jsp

  

 

 3.通过Servlet来访问definition(tiles.index.definition),可编程式!

   


1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

16

17

18

19

20

21

22

23

24

25

26

27

28

29

30

31

32

33

34

35

36

37

38

39

40

41

42

43

44

45

46

47

48

49

50

51

package secondriver.tiles.servlet;

 

import java.io.IOException;

 

import javax.servlet.ServletException;

import javax.servlet.http.HttpServlet;

import javax.servlet.http.HttpServletRequest;

import javax.servlet.http.HttpServletResponse;

 

import org.apache.tiles.Attribute;

import org.apache.tiles.Definition;

import org.apache.tiles.TilesContainer;

import org.apache.tiles.access.TilesAccess;

import org.apache.tiles.request.ApplicationContext;

import org.apache.tiles.request.Request;

import org.apache.tiles.request.servlet.ServletRequest;

import org.apache.tiles.request.servlet.ServletUtil;

 

public class TilesServlet extends HttpServlet {

 

    private static final long serialVersionUID = 2721434552222217027L;

 

    @Override

    protected void service(HttpServletRequest request,

            HttpServletResponse response) throws ServletException, IOException {

 

        ApplicationContext applicationContext = ServletUtil

                .getApplicationContext(getServletContext());

 

        TilesContainer container = TilesAccess.getContainer(applicationContext);

        Request currentRequest = new ServletRequest(applicationContext,

                request, response);

 

        Definition definition = container.getDefinition(

                "tiles.index.definition", currentRequest);

        definition.putAttribute("title"new Attribute("通过servlet访问"));

        definition.putAttribute("body"new Attribute(

                "这是通过Servlet处理后的definition."));

        container.render(definition, currentRequest);

 

        /**

         * 不需要处理的时候可以直接使用definition的name

         

         * tiles.index.definition没有定义title属性

         

         * 而template文件(布局)中用到所以需要在Servlet中进行添加

         */

        // container.render("tiles.index.definition", currentRequest);

 

    }

}

  访问:/tiles/tilesservlet

 

 

 注意:

  •  这里使用了Servlet需要在web.xml中增加Servlet的配置

1

2

3

4

5

6

7

8

<servlet>

        <servlet-name>tilesservlet</servlet-name>

        <servlet-class>secondriver.tiles.servlet.TilesServlet</servlet-class>

    </servlet>

    <servlet-mapping>

        <servlet-name>tilesservlet</servlet-name>

        <url-pattern>/tilesservlet</url-pattern>

    </servlet-mapping>

  •  在pom.xml中添加servlet-api:

 


1

2

3

4

5

<dependency>

            <groupId>javax.servlet</groupId>

            <artifactId>servlet-api</artifactId>

            <version>2.5</version>

        </dependency>

 

 

4.通过标签在响应页面上配置definition,并插入到页面中

  


1

2

3

4

5

6

7

8

9

10

11

12

13

<%@ page language="java" contentType="text/html; charset=UTF-8"

    pageEncoding="UTF-8"%>

<%@ taglib uri="http://tiles.apache.org/tags-tiles" prefix="tiles"%>

 

<tiles:definition name="tiles.runtime.definiation"

    template="/layout/index_layout.jsp" extends="tiles.base.definition">

    <tiles:putAttribute name="title" value="通过标签配置 definition." />

    <tiles:putAttribute name="body">

        通过tiles标签配置的运行时definition

    </tiles:putAttribute>

</tiles:definition>

 

<tiles:insertDefinition name="tiles.runtime.definiation"></tiles:insertDefinition>

 

  访问:/tiles/example/runtime.jsp

  

 

本文通过多种方式展示了Tiles的使用和其灵活性。另外Tiles还可以和Freemarker,Velocity,Spring,Struts等多种框架集成使用。

 

具体可以参考官方文档:http://tiles.apache.org/framework/whats-new.html。 

另外更多的示例:http://tiles.apache.org/download.html

 

http://aiilive.blog.51cto.com/1925756/1596069

 

时间: 2024-08-06 20:18:24

使用Apache Tiles3.x构建界面布局的相关文章

iOS界面布局之三——纯代码的autoLayout及布局动画

iOS界面布局之三--纯代码的autoLayout及布局动画 一.引言         关于界面布局,apple的策略已经趋于成熟,autolayout的优势在开发中也已经展现的淋漓尽致.除了使用storyBoard进行布局约束的拖拽,有时我们也需要在代码中进行autolayout的布局设置,Masonry库可以方便的创建约束属性,实际上,我们也没有必要再使用系统原生的代码来创建和设置约束,这篇博客只作为使用的方法备忘.前几篇布局介绍的链接如下: 使用autoresizing进行界面布局:htt

高分辨率下界面布局的解决方案

分辨率|解决 高分辨率下文字字体.图像.界面布局的解决方案 为什么要保证我们的软件产品或应用程序中的文本.图像和字体.布局等问题呢,因为我们用户的终端显示设备通常型号和设置各异,如最近出现的16×9,低于8"的等最新款式移动手提电脑,我们的应用程序和软件产品通常会在这样的终端变得面目全非,而这显然给用户的使用带来了严重的问题,直接导致的问题如:操作易用性Usability.功能可接近性Accessibility.文本可读性Readability 等,而这样的问题并非不可逾越,要解决如何让我们的应

手机客户端的两种主要的界面布局与设计方式

本文主要讨论手机手机客户端的两种主要的界面布局与设计方式,对于手机设计师来说,此类文章比较少见,当然其中对于用于体验与可用性的实现依然很普遍. 手机产品设计与传统的桌面和web产品设计相比,最显著的约束是设计空间的急剧缩小.打个比方,这就像从一个100平米的房子搬到5平米的单间,东西没少一样,可以施展的空间却小了几十倍.更重要的是,在这样一个小空间里,你不能把东西胡乱摆放,要依旧保持它们的清晰.合理.简洁.美观.借用<用户体验的要素>中的名词,这涉及到"框架层"的设计问题,

学Silverlight 2系列(3):界面布局

本文为系列文章第三篇,学习Silverlight 2中的界面布局,Silverlight 2 中新增加了Grid和Panel两个布局容器,使得界面布局更加的强大和灵活. Canvas面板 Canvas是在Silverlight 1.0时代就有的一种基础布局面板,它采用绝对坐标 定位.可以使用附加属性(Attached Property)对Canvas中的元素进行定位, 通过附加属性我们指定控件相对于其直接父容器Canvas 控件的上.下.左.右 坐标的位置.如下面的XAML声明了两个矩形,它们分

整合apache和tomcat构建Web服务器

linux是最常用的web服务器,本节我们将通过整合apache和tomcat构建一个java/jsp运行平台,详细介绍web服务器的搭建过程. 一.apache与tomcat整合的必要性 Apache是最流行的Web服务器,开放源代码,支持跨平台的应用(可以运行在几乎所有的Linux.Unix.Windows系统平台上),尤其对Linux的支持相当完美. apache的优点有: 功能强大,apache自带了很多功能模块,可根据需求编译自己需要的模块. 配置简单,apache的配置文件非常简单,

基于Java的界面布局DSL设计与实现

界面设计应该是一项充满创造性.富有乐趣的工作,但是却往往被认为非常的枯燥和繁琐.究其原因,是因为界面布局领域所采用的描述概念和具体的实现语言之间存在很大的语义隔阂.而一般的界面开发工具提供的所见即所得以及界面布局管理器等方案也无法很好地解决这个问题. 在本文中,我们会给出一种更好的解决方案,我们不是去试图把界面设计者头脑中的设计概念和样式逐步降级.分解成所使用的实现语言能够理解的低层概念,也不是提供一些已经完成的.确定的但难以扩充和更改的布局样式库供界面设计者使用.我们所提供的是一种专门用于描述

win8更改开始界面布局行数

  1.更改开始界面布局行数 默认情况下 Win8 开始屏幕应用瓷贴行数是根据你的显示器分辨率大小来排列的,例如你的显示器分辨率是1024 x 768,Win8开始屏幕应用只有4行. 1900 X 1080 或更高的分辨率最多能显示6行,如果你想减少或者增加瓷贴行数,可以通过修改注册表实现. 修改Win8开始屏幕应用瓷贴行数:快捷键Win+R – 输入regedit – 找到 HKEY_CURRENT_USERSoftwareMicrosoftWindowsCurrentVersionImmer

app-Android怎么根据节日来动态的更换界面布局?

问题描述 Android怎么根据节日来动态的更换界面布局? 就像淘宝App一样,可以根据更个节日来更换相对应的主题界面,并且不需要更新App.这种要怎么实现? 解决方案 后台给你数据,比如后台给你一个标识的type,==1的时候是正常显示,==2的时候显示下雨天,==3的时候显示下雪天.等等这样子,如果图那些呢,可以做本地,也可以后台给你传. 解决方案二: 启动时判断时间,动态加载布局网上的教程有很多请自行百度. 解决方案三: 最好是动态的从服务器上去获取页面布局下来进行布局,比如获取一个htm

AppleWatch开发入门二——界面布局

AppleWatch开发入门二--界面布局 一.简介         在iphone开发中,最基本的布局方式是通过frame,将控件的位置和大小固定在屏幕上,后来,由于手机屏幕的尺寸有了略微变化,有了autoresizing的布局框架,我们可以设置子视图随父视图的改变做一些相应的变化,再后来,iphone的尺寸与分辨率也越来越多,适配各个屏幕也成为了iOS开发者遇到的新的问题,幸运的是,autolayout机制的出现,大大减小了开发者在适配方面的成本.以上提到的两种布局方式,在以前博客中有讨论: