jsp中sitemesh修改tagRule技術(shù)分享

sitemesh默認(rèn)提供了一些常用的rule

可以看到其實可以選擇

/**
 * 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默認(rèn)填上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>

這樣就可以很簡單的放入到任意位置!?。?/p>

弊端

這樣雖然很簡單 但是也存在一些問題 開發(fā)如果需要增加新的content必須要要到母版頁【對的 其實sitemesh不就像是asp.net中的母版頁么】

增加對應(yīng)的sitemesh:write標(biāo)簽

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

并且上述代碼中同樣存在覆蓋的問題 比如多處使用了同樣的tagid

解決

sitemesh似乎沒有提供直接用來拼接多個的tagrule

如果有需求將某塊元素放入到末尾 可以考慮增加tagrule

在processend時直接將對應(yīng)的元素直接append

最終可以直接輸出

以上就是我們給大家整理的本次教程的全部內(nèi)容,感謝你對碩編程的支持。

相關(guān)文章
亚洲国产精品第一区二区,久久免费视频77,99V久久综合狠狠综合久久,国产免费久久九九免费视频