首先要感谢发明Markdown的家伙,这东西真是好用吖!
###SiteMesh概述 嗯,请自行Google之。
###教程:一分钟完成Template模板组合
####1.内容页面 简单的示例内容页面源代码如下:
<html>
<head>
<meta http-equiv="Content-Type" content="text/html; charset=utf-8">
<meta name="theme" content="basic_theme" />
<title>应该是内容页面</title>
</head>
<body>
<h1>Weekdays</h1>
<p>5:00pm - 10:00pm</p>
<p>Weekends</p>
<p>5:00pm - 10:00pm</p>
<a href="${pageContext.request.contextPath}/download/decorators.jsp">down</a>
</body>
</html>
在源代码中加入 <meta name="theme" content="basic_theme" />
即可由SiteMesh自动完成Template模板装配。
####2.Runtime环境配置
-
WEB-INF目录下添加 sitemesh.xml,文件内容中除了指定 decoration-file 路径的属性需定制外,其他内容基本不需更改。
<?xml version="1.0" encoding="UTF-8"?> <sitemesh> <!-- 注意这一行指定的decorators.xml文件的存放位置 --> <property name="decorators-file" value="/WEB-INF/themes/decorators.xml" /> <excludes file="${decorators-file}" /> <page-parsers> <parser content-type="text/html" class="com.opensymphony.module.sitemesh.parser.HTMLPageParser" /> </page-parsers> <decorator-mappers> <mapper class="com.opensymphony.module.sitemesh.mapper.PageDecoratorMapper"> <!-- 注意这一行指定<meta/>标签的 name 属性作为PageDecorator的识别符号 --> <param name="property.1" value="meta.theme" /> </mapper> <mapper class="com.opensymphony.module.sitemesh.mapper.FrameSetDecoratorMapper" /> <mapper class="com.opensymphony.module.sitemesh.mapper.PrintableDecoratorMapper"> <param name="decorator" value="printable" /> <param name="parameter.name" value="printable" /> <param name="parameter.value" value="true" /> </mapper> <mapper class="com.opensymphony.module.sitemesh.mapper.FileDecoratorMapper" /> <mapper class="com.opensymphony.module.sitemesh.mapper.ConfigDecoratorMapper"> <param name="config" value="${decorators-file}" /> </mapper> </decorator-mappers> </sitemesh>
-
WEB-INF/lib 目录下加入 sitemesh-2.4.2.jar
这个可以自己在github上获取最新版本,话说 sitemesh 3.0 好像无疾而终了?
-
WEB-INF/web.xml 文件中加入。重点是
<url-pattern>*.jsp</url-pattern>
,为了防止SiteMesh随意处理各类图片、Javascript或StyleSheets资源,最好指定后缀或url路径。<filter> <filter-name>sitemesh</filter-name> <filter-class>com.opensymphony.sitemesh.webapp.SiteMeshFilter</filter-class> </filter> <filter-mapping> <filter-name>sitemesh</filter-name> <url-pattern>*.jsp</url-pattern> <dispatcher>FORWARD</dispatcher> <dispatcher>REQUEST</dispatcher> </filter-mapping>
-
最后也是最重要的 decorators.xml文件
<?xml version="1.0" encoding="UTF-8"?> <decorators defaultdir="/WEB-INF/themes"> <decorator name="basic_theme" page="basic_theme.jsp" /> </decorators>
这里的
<decorator name="basic_theme" .../>
,对应你的内容文件中的<meta name="theme" content="basic_theme" />
额外说明的是:这里使用Page模型组合Template模板,因为最简单!
<decorator-mappers>
<mapper class="com.opensymphony.module.sitemesh.mapper.PageDecoratorMapper">
<param name="property.1" value="meta.theme" />
</mapper>
...
来源:oschina
链接:https://my.oschina.net/u/52781/blog/110487