sitemesh 學習之 meta 引入


在上篇筆記學習了sitemesh的基本用法,這里還有另一種用法

在sitemesh.jar有一個默認的 sitemesh-default文件 ,這個文件是可以指定的
可以指定的文件名的sitemesh.xml文件,放在/WEB-INF目錄下。如果沒用,則默認讀取sitemesh.jar文件中的sitemesh-default.xml文件。這個文件在jar:com.opensymphony.module.sitemesh.factory包中。
在這個文件中可以指定使用那些mapper對象來裝飾頁面,也可以擴展自己的Mapper類。 sitemesh自帶的mapper類放在com.opensymphony.module.sitemesh.mapper包中,可以供大家選擇使用。

sitemesh-default.xml的內容

   
   
   
           
  1. <sitemesh>
  2. <property name="decorators-file" value="/WEB-INF/decorators.xml"/>
  3. <excludes file="${decorators-file}"/>
  4. <page-parsers>
  5. <parser content-type="text/html" class="com.opensymphony.module.sitemesh.parser.HTMLPageParser" />
  6. </page-parsers>
  7. <decorator-mappers>
  8. <mapper class="com.opensymphony.module.sitemesh.mapper.PageDecoratorMapper">
  9. <param name="property.1" value="meta.decorator" />
  10. <param name="property.2" value="decorator" />
  11. </mapper>
  12. <mapper class="com.opensymphony.module.sitemesh.mapper.FrameSetDecoratorMapper"/>
  13. <mapper class="com.opensymphony.module.sitemesh.mapper.PrintableDecoratorMapper">
  14. <param name="decorator" value="printable" />
  15. <param name="parameter.name" value="printable" />
  16. <param name="parameter.value" value="true" />
  17. </mapper>
  18. <mapper class="com.opensymphony.module.sitemesh.mapper.FileDecoratorMapper"/>
  19. <mapper class="com.opensymphony.module.sitemesh.mapper.ConfigDecoratorMapper">
  20. <param name="config" value="${decorators-file}" />
  21. </mapper>
  22. </decorator-mappers>
  23. </sitemesh>

這里是今天學習備注的重點 , com.opensymphony.module.sitemesh.mapper.PageDecoratorMapper 這個類的使用。
 
在sitemesh-default.xml中,可以看到已經聲明了這個類,並且可以通過查閱API來獲得其使用方法。
在這個文件中可以看到配置了這個類的兩個屬性

   
   
   
           
  1. <param name="property.1" value="meta.decorator" />
  2. <param name="property.2" value="decorator" />

通過查閱API可以找到,只要html文件中包含

   
   
   
           
  1. <meta name="decorator" content="decoratorname">
  2. <meta name="meta.decorator" content="decoratorname">

 就可以應用相應的裝飾器,而不必在decorator.xml中使用<pattern>來規定哪些頁面使用哪些裝飾器。

decorators.xml

   
   
   
           
  1. <?xml version="1.0" encoding="UTF-8"?>
  2. <decorators defaultdir="/WEB-INF/views">
  3. <!-- 默認裝飾頁面, 在需要裝飾的頁面增加<meta name="decorator" content="default"/> -->
  4. <decorator name="blank" page="layouts/blank.jsp" />
  5. <decorator name="default" page="layouts/default.jsp" />
  6. <!-- CMS基礎主題裝飾頁面 -->
  7. <decorator name="cms_default_basic" page="modules/cms/front/themes/basic/layouts/default.jsp" />
  8. <decorator name="cms_default_weixin" page="modules/cms/front/themes/weixin/layouts/default.jsp" />
  9. </decorators>


裝飾頁面為blank

某一個需要被裝飾的頁面不用<pattern>來攔截

xxx.jsp 被裝飾的頁面
   
   
   
           
  1. <%@ page contentType="text/html;charset=UTF-8" %>
  2. <%@ include file="/WEB-INF/views/include/taglib.jsp"%>
  3. <html>
  4. <head>
  5. <title>${fns:getConfig('productName')}</title>
  6. <meta name="decorator" content="blank"/><c:set var="tabmode" value="${empty cookie.tabmode.value ? '0' : cookie.tabmode.value}"/>
  7. <c:if test="${tabmode eq '1'}"><link rel="Stylesheet" href="${ctxStatic}/jerichotab/css/jquery.jerichotab.css" />
  8. <script type="text/javascript" src="${ctxStatic}/jerichotab/js/jquery.jerichotab.js"></script></c:if>
  9. <style type="text/css">
  10. #main {padding:0;margin:0;} #main .container-fluid{padding:0 4px 0 6px;}
  11. #header {margin:0 0 8px;position:static;} #header li {font-size:14px;_font-size:12px;}
  12. #header .brand {font-family:Helvetica, Georgia, Arial, sans-serif, 黑體;font-size:26px;padding-left:33px;}
  13. #footer {margin:8px 0 0 0;padding:3px 0 0 0;font-size:11px;text-align:center;border-top:2px solid #0663A2;}
  14. #footer, #footer a {color:#999;} #left{overflow-x:hidden;overflow-y:auto;} #left .collapse{position:static;}
  15. #userControl>li>a{/*color:#fff;*/text-shadow:none;} #userControl>li>a:hover, #user #userControl>li.open>a{background:transparent;}
  16. </style>


看到只要頭部引用了 <meta name="decorator" content="blank"/> 這個meta,就會自動去 decorators.xml 找  decorator name為meta指定的進行裝飾操作 ,這個方法跟用<pattern>用起來都很方便,只是使用meta控制的粒度更細


一點聯想:
 
   在com.opensymphony.module.sitemesh.mapper包中我看到了一個叫CookieDecoratorMapper的類,話說可以在用戶的cookie中指定裝飾器的名字。
 
這樣我們可以通過擴展來實現基於用於的個人喜好設定,用戶可以自己選擇需要應用的裝飾器(有點類似QQ空間選擇個性主頁模板),把裝飾器的的名稱存放起來,當瀏覽頁面的時候自動去讀取這個值以實現主頁風格的動態切換。只是有個這個想法,沒有實踐





免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM