要须心地收汗马,孔孟行世目杲杲。这篇文章主要讲述SiteMesh2-sitemesh.xml的PageDecoratorMapper映射器的用法相关的知识,希望能为你提供帮助。
继上一章http://www.cnblogs.com/EasonJim/p/7083165.html中使用的例子中,是通过decorators.xml文件通过URL匹配进行转换的。
而下面这种方法是通过sitemesh.xml的PageDecoratorMapper映射器来转换的,而无需匹配URL,只需在meta头指定decorator中的模板即可。
下面是操作步骤:
1、在sitemesh.xml中添加PageDecoratorMapper映射器,并指定meta的名称规则
< mapper class="com.opensymphony.module.sitemesh.mapper.PageDecoratorMapper"> < param name="property.1" value="https://www.songbingjia.com/android/meta.decorator" /> < param name="property.2" value="https://www.songbingjia.com/android/decorator" /> < !-- 注意这一行指定< meta/> 标签的 name 属性作为PageDecorator的识别符号 --> < param name="property.3" value="https://www.songbingjia.com/android/meta.theme" /> < /mapper>
用法:
【SiteMesh2-sitemesh.xml的PageDecoratorMapper映射器的用法】①< meta name="decorator" content="basic-theme" />
②< meta name="them" content="basic-theme" />
③< param name="property.2" value="https://www.songbingjia.com/android/decorator" /> 这个用法在下方将有说明。
注意:content指定的就是在decorators.xml文件中docorator的模板名称。
2、在decorators.xml的模板配置还是使用原来的
< decorators defaultdir="/decorators"> < decorator name="basic-theme" page="basic-theme.jsp"> < pattern> /data/*< /pattern> < /decorator> < /decorators>
3、在根目录新建index.jsp页面,内容如下:
< %@ page language="java" contentType="text/html; charset=UTF-8" pageEncoding="UTF-8"%> < !DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/TR/html4/loose.dtd"> < html> < head> < meta http-equiv="Content-Type" content="text/html; charset=utf-8"> < meta name="decorator" 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> < /body> < /html>
4、测试效果如下:
文章图片
文章图片
5、< param name="property.2" value="https://www.songbingjia.com/android/decorator" /> 的用法
①新建test.jsp
< %@ page language="java" contentType="text/html; charset=UTF-8" pageEncoding="UTF-8"%> < !DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/TR/html4/loose.dtd"> < html decorator="basic-theme"> < head> < meta http-equiv="Content-Type" content="text/html; charset=utf-8"> < title> < /title> < /head> < body> < h1> Test< /h1> < /body> < /html>
②直接访问test.jsp页面,得到的效果就是使用了模板页面的,效果如下:
文章图片
文章图片
测试工程:https://github.com/easonjim/5_java_example/tree/master/sitemesh/test2
参考:
http://wiki.sitemesh.org/wiki/display/sitemesh/Decorating+Beyond+URL+Patterns
https://my.oschina.net/yangning/blog/110487
https://web.archive.org/web/20071008180624/http://www.opensymphony.com/sitemesh/api/com/opensymphony/module/sitemesh/mapper/PageDecoratorMapper.html
推荐阅读
- 07_apply rolling updates to a service
- android 自定义控件之简单的loading框
- app-framework学习--nav的Scroller禁用与启用
- React Native解决安卓图片被挤压
- Android NDK 编译选项设置[zhuan]
- Android-ViewPager+Fragment数据更新问题
- Hybrid app(cordova) 环境配置记录
- android ndk 编译的时候指令集的选取
- 15款适用于MAC的最佳屏幕录制软件 [免费/付费]