欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页  >  IT编程

jsp中sitemesh修改tagRule技术分享

程序员文章站 2022-08-30 11:47:53
sitemesh默认提供了一些常用的rule 可以看到其实可以选择 /** * extracts the contents of any element...

sitemesh默认提供了一些常用的rule

jsp中sitemesh修改tagRule技术分享

可以看到其实可以选择

/**
 * extracts the contents of any elements that look like
 * <code>&lt;content tag='foo'&gt;...&lt;/content&gt;</code> and write the contents
 * to a page property (page.foo).
 *
 * <p>this is a cheap and cheerful mechanism for embedding multiple components in a
 * page that can be used in different places in decorators.</p>
 *
 * @author joe walnes
 */
public class contentblockextractingrule extends basicblockrule<string> {
 private final contentproperty propertytoexport;
 public contentblockextractingrule(contentproperty propertytoexport) {
  this.propertytoexport = propertytoexport;
 }
 @override
 protected string processstart(tag tag) throws ioexception {
  tagprocessorcontext.pushbuffer();
  return tag.getattributevalue("tag", false);
 }
 @override
 protected void processend(tag tag, string tagid) throws ioexception {
  propertytoexport.getchild(tagid).setvalue(tagprocessorcontext.currentbuffercontents());
  tagprocessorcontext.popbuffer();
 }
}

修改scripttagrulebundle处理如下

public class scripttagrulebundle implements tagrulebundle {
 @override
 public void install(state defaultstate, contentproperty contentproperty, sitemeshcontext sitemeshcontext) {
  defaultstate.addrule("content", new contentblockextractingrule(contentproperty.getchild("page")));
 }
 @override
 public void cleanup(state defaultstate, contentproperty contentproperty, sitemeshcontext sitemeshcontext) {
 }
}

用法很简单使用content作为tag默认填上tag即可

比如

<content tag="reference">
<script type="text/javascript" src="<%=path%>/plugins/select2/js/select2.min.js"></script>
<script type="text/javascript" src="<%=path%>/plugins/select2/js/i18n/zh-cn.js"></script>
<script type="text/javascript" src="<%=path%>/plugins/bootstrap-modal/js/bootstrap-modal.js"></script>
<script type="text/javascript" src="<%=path%>/plugins/bootstrap-modal/js/bootstrap-modalmanager.js"></script>
</content>

在模板中这样

<body class="mainbody">
<sitemesh:write property='body'/>
<sitemesh:write property='page.reference'/>
</body>

这样就可以很简单的放入到任意位置!!!

弊端

这样虽然很简单 但是也存在一些问题 开发如果需要增加新的content必须要要到母版页【对的 其实sitemesh不就像是asp.net中的母版页么】

增加对应的sitemesh:write标签

propertytoexport.getchild(tagid).setvalue(tagprocessorcontext.currentbuffercontents());

并且上述代码中同样存在覆盖的问题 比如多处使用了同样的tagid

解决

sitemesh似乎没有提供直接用来拼接多个的tagrule

如果有需求将某块元素放入到末尾 可以考虑增加tagrule

在processend时直接将对应的元素直接append

最终可以直接输出

以上就是我们给大家整理的本次教程的全部内容,感谢你对的支持。