对于spring 集成 tiles3 简单介绍
网站一般分为可重复使用的模板正在呈现不同的网页之间的的。例如,一个网站中包含的页眉,页脚,菜单等项目仍然通过了该网站相同,并给它一个共同的外观和感觉。这是很难很难的代码在每一个网页,如果以后需要改变是不是所有的页面需要修改。因此,我们使用模板化机制。我们创建一个共同的页眉,页脚,菜单页,其中包括在每一页。
首先Spring - servlet.xml 中定义Tiles
<bean id="viewResolver"
class="org.springframework.web.servlet.view.UrlBasedViewResolver">
<property name="order" value="1" />
<property name="viewClass">
<value>
org.springframework.web.servlet.view.tiles3.TilesView
</value>
</property>
</bean>
<bean id="tilesConfigurer"
class="org.springframework.web.servlet.view.tiles3.TilesConfigurer">
<property name="definitions">
<list>
<value>classpath:tiles.xml</value>
</list>
</property>
</bean>
具体介绍在前面spring-mvc-web.xml有。
定义tiles.xml文件
<?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">
<tiles-definitions>
<definition name="tiles.news.edit" template="/WEB-INF/tiles/main.jsp">
<put-attribute name="content" value="/WEB-INF/views/news_edit.jsp" />
</definition>
<definition name="tiles.news.login" template="/index.jsp" />
<definition name="tiles.news.editdailymessage" template="/WEB-INF/tiles/main.jsp">
<put-attribute name="content" value="/WEB-INF/views/dailymessage_edit.jsp" />
</definition>
<definition name="tiles.supplier.manage" template="/WEB-INF/tiles/main.jsp">
<put-attribute name="content" value="/WEB-INF/views/supplier_manage.jsp" />
</definition>
</tiles-definitions>
属性 | ||||
名称 | 是否必须 | 值必须 | 值类型 | 说明 |
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。 |
创建视图,在视图中引用
......
<tr>
<td><tiles:insertAttribute name="content" /></td>
</tr>
......
自此,tiles3的配置完成, 当controller类进行访问时就可以进行灵活的模块改变了。
注意,访问时访问的是definition的name,然后访问到模板文件template。