SiteMesh 是一个很好的 Java Web 模板框架,它的思维方式与通常的模板实现(比如 Tiles 或 include)有些区别。SiteMesh 模板一旦配置好后,在编辑内容页时可以忽视它的存在。可以它是被动,内容页中的输出被抽取到模板中,一般的模板为主动的把自己某部分内容去填充模板。
在站点中应用样式或 JS 代码时很可能会依赖于每个页面的 <body> 的 id,比如:
body#archive primary{....} /** 样式 **/
$("body#archive").bgColor='red'; //JS
所以就要求每个页面有不同的 body id 值。在很多 SiteMesh 的例子中页面渲染后 body 都没有 id 值的,或是相同的 id 值。
其实原本是想用 SiteMesh 3 的,当前仍为 Alpha 版,SiteMesh 3 比 SiteMesh 2 要更简单,装饰文件可以不是 jsp,但是要为每个页面设置不同的 body.id 时死活都没成功,它怎么都不认可 <body <sitemesh:write property='body.id'/>> 这样的写法。所以不得再到 SiteMesh 2 里去寻求解决办法,也难怪,本来 Alpha 就是个内测版,极不成熟的。
SiteMesh 2 的最新版本是 2.4.1,2009-3-15 出品的,项目主页在:http://www.opensymphony.com/sitemesh。
SiteMesh 3 的最新版本是 3.0 Alpha 1,更新日期为 2009-9-6 日,http://www.sitemesh.org,目前被墙中。
那就来看在 SiteMesh 2 中怎么为每个页面指定不同的 body.id 值,有两种办法,都是在模板文件中配置,假如 decorators.xml 文件中的配置如下:
1 2 3 4 5 6 7 |
<?xml version="1.0" encoding="utf-8"?> <decorators defaultdir="/decorators"> <decorator name="main" page="main.jsp"> <pattern>/*</pattern> </decorator> </decorators> |
那么在写 /decorators/main.jsp 文件的 <body> 标签时可有两种写法:
1. 直观的取被渲染页的 body.id 值赋给 id 属性:
<body id="<decorator:getProperty property='body.id'/>">
2. 把被渲染页 body 的 id 属性及值一起搬过来:
<body<decorator:getProperty property="body.id" writeEntireProperty="true" />>
用了 writeEntireProperty 属性,会把被渲染页的属性名及其值一起搬过来,并且在属性之前会加个空格。
现在在内容页(前面称作被渲染页中) 的 <body> 标签就应该加上自己的 id 值了,被渲染后,这个 body.id 被搬到装饰页中 <body> 标签中,也就是当前页面的 body.id 了。
比如,被渲染的 index.jsp 页面中的 <body> 写作:<body id="body-id-of-index-jsp">,执行之后看到的页面的 body.id 就是 body-id-of-index-jsp 了。
来看个图:
可下载该示例的完整可直接运行的程序 war 包:test-sitemesh2.war。
参考资料:1. http://pratinas.net/wiki/SiteMesh
2. SiteMesh - SiteMesh Tag Reference
本文链接 https://yanbin.blog/sitemesh2-different-body-id/, 来自 隔叶黄莺 Yanbin Blog
[版权声明] 本文采用 署名-非商业性使用-相同方式共享 4.0 国际 (CC BY-NC-SA 4.0) 进行许可。