教程:一分钟完成SiteMesh Template模板组合

首先要感谢发明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>
        ...

你可能感兴趣的:(Web,dynamic,template,sitemesh)