Tiles与YUI LayoutManager的结合

来源:互联网 发布:万万没想到 知乎 编辑:程序博客网 时间:2024/06/05 11:44

 最近在学习YUI,深感功能全面,正在试探是否可以作为页面部分的一揽子解决方案。
现在只发现缺少页面组装的功能,看来不得不依赖 apache tiles 了。
这两天做了个小例子,结合了YUI的LayoutManager和Tiles的功能,现在贴出来,欢迎对YUI感兴趣的朋友指正。
也欢迎对YUI感兴趣的朋友谈谈在企业开发里YUI的长处和短处。

首先是tiles的模板jsp文件,其中由tiles管理的Attribute都放在了中,这些又是LayoutManager的管理对象,代码如下:

  1. <%@ taglib uri="http://tiles.apache.org/tags-tiles" prefix="tiles"%>
  2. <html>
  3. <head>
  4. <title><tiles:getAsString name="title" /></title>
  5. <%
  6.     String path = request.getContextPath();
  7. %>
  8. <link rel="stylesheet" type="text/css" href="<%=path%>/yui/assets/skins/sam/resize.css">
  9. <link rel="stylesheet" type="text/css" href="<%=path%>/yui/assets/skins/sam/layout.css">
  10. <link rel="stylesheet" type="text/css" href="<%=path%>/yui/logger/assets/skins/sam/logger.css">
  11. <script type="text/javascript" src="<%=path%>/yui/yahoo-dom-event/yahoo-dom-event.js"></script>
  12. <script type="text/javascript" src="<%=path%>/yui/dragdrop/dragdrop-min.js"></script>
  13. <script type="text/javascript" src="<%=path%>/yui/element/element-beta-min.js"></script>
  14. <script type="text/javascript" src="<%=path%>/yui/logger/logger-min.js"></script>
  15. <script type="text/javascript" src="<%=path%>/yui/animation/animation-min.js"></script>
  16. <script type="text/javascript" src="<%=path%>/yui/resize/resize-min.js"></script>
  17. <script type="text/javascript" src="<%=path%>/yui/layout/layout-min.js"></script>
  18. <script type="text/javascript">
  19.     function initLayout() {
  20.         var layout = new YAHOO.widget.Layout( {
  21.             units : [ {
  22.                 position :'top',
  23.                 height :50,
  24.                 body :'titlebar'
  25.             }, {
  26.                 position :'bottom',
  27.                 height :50,
  28.                 body :'statusbar'
  29.             }, {
  30.                 position :'center',
  31.                 body :'content'
  32.             } ]
  33.         });
  34.         layout.render();
  35.     };
  36.     YAHOO.util.Event.onDOMReady(initLayout);
  37. </script>
  38. </head>
  39. <body class="yui-skin-sam">
  40. <script type="text/javascript">
  41.     var myLogReader = new YAHOO.widget.LogReader();
  42. </script>
  43. <div id="titlebar"><tiles:insertAttribute name="header" /></div>
  44. <div id="content">
  45. <table>
  46.     <tr>
  47.         <td><tiles:insertAttribute name="menu" /></td>
  48.     </tr>
  49.     <tr>
  50.         <td><tiles:insertAttribute name="body" /></td>
  51.     </tr>
  52. </table>
  53. </div>
  54. <div id="statusbar"><tiles:insertAttribute name="footer" /></div>
  55. </body>
  56. </html>

其次是tiles的定义文件,其中有一个抽象页面定义和三个具体的页面定义,代码如下:

  1. <?xml version="1.0" encoding="UTF-8"?>  
  2. <!DOCTYPE tiles-definitions PUBLIC   
  3.        "-//Apache Software Foundation//DTD Tiles Configuration 2.0//EN"   
  4.        "http://tiles.apache.org/dtds/tiles-config_2_0.dtd">  
  5. <tiles-definitions>  
  6.     <definition name="simpleweb.common" template="/pages/tiles/mainlayout.jsp">  
  7.         <put-attribute name="title" value="Simpleweb" />  
  8.         <put-attribute name="header" value="/pages/banner.jsp" />  
  9.         <put-attribute name="menu" value="/pages/mainmenu.jsp" />  
  10.         <put-attribute name="footer" value="/pages/footer.jsp" />  
  11.         <put-attribute name="body" value="" />  
  12.     </definition>  
  13.   
  14.     <definition name="simpleweb.main" extends="simpleweb.common">  
  15.         <put-attribute name="body" value="/pages/welcome.jsp" />  
  16.     </definition>  
  17.        
  18.     <definition name="simpleweb.person.register" extends="simpleweb.common">  
  19.         <put-attribute name="body" value="/pages/person/register.jsp" />  
  20.     </definition>  
  21.        
  22.     <definition name="simpleweb.person.search" extends="simpleweb.common">  
  23.         <put-attribute name="body" value="/pages/person/search.jsp" />  
  24.     </definition>  
  25. </tiles-definitions> 

通过使用struts2-tiles-plugin,画面的迁移需要在struts.xml中这样定义:

  1. <result-types>  
  2.     <result-type name="tiles"    
  3.         class="org.apache.struts2.views.tiles.TilesResult" />  
  4. </result-types>  
  5.   
  6. <action name="LoginAction" method="execute" class="loginAction">  
  7.     <result name="input">/index.jsp</result>  
  8.     <result name="success" type="tiles">simpleweb.main</result>  
  9. </action>  

这样,就可以实现一个由YUI LayoutManager进行布局的页面中,页面的各个组成部分通过tiles进行定义和组装。

原创粉丝点击