• <ins id="pjuwb"></ins>
    <blockquote id="pjuwb"><pre id="pjuwb"></pre></blockquote>
    <noscript id="pjuwb"></noscript>
          <sup id="pjuwb"><pre id="pjuwb"></pre></sup>
            <dd id="pjuwb"></dd>
            <abbr id="pjuwb"></abbr>

            Shuffy

            不斷的學習,不斷的思考,才能不斷的進步.Let's do better together!
            posts - 102, comments - 43, trackbacks - 0, articles - 19

            Tiles框架使用總結

            Posted on 2011-10-09 10:45 Shuffy 閱讀(628) 評論(0)  編輯 收藏 引用 所屬分類: 在線推薦閱讀JavaWeb開發技術

            Tiles框架的提出背景:
            傳統的GUI工具包,如Java AWT和Java Swing,都提供了一些功能強大的布局管理器,它們指定各個視圖組件在窗口中的分布位置。布局管理器有助于創建復合式的復雜界面,一個復合式界面由一些簡單的基本界面組成。
            利用布局管理器來創建GUI界面有以下優點:
                     可重用性:基本界面可以被重用,組合成各種不同的復合式界面
                     可擴展性:可以方便的擴展基本界面,從而創建更復雜的界面(其實此處我的感覺并非如此,可擴展性并不是為了創建復雜界面的,越是復雜的界面在比較獨立的情況下更容易創建。)
                     可維護性:每個基本界面之間相互獨立,當復合式界面中的局部區域發生變化,不會影響其它區域
                     不幸的是,JSP技術本身并沒有直接提供布局或布局管理器。為了簡化Web頁面的開發,提高可重用性和可擴展性,Struts Tiles框架提供了一種模板機制,模板定義了網頁的布局,同一模板可以被多個Web頁面共用。此外,Tiles框架還允許定義可重用的Tiles組件,它可以描述一個完整的網頁,也可以描述網頁的局部內容。簡單的Tiles組件可以被組合或擴展成為更復雜的Tiles組件。
             
             
            Tiles框架的基本用法:
                   使用Tiles框架大大提高了視圖層程序代碼的可重用性、可擴展性和可維護性,也增加了開發視圖的難度和復雜度,在使用Tiles框架之前一定要結合Web應用的規模。
            在開發Web站點時,常常要求同一站點的所有Web頁面保持一致的外觀,比如有相同的布局、頁頭、頁尾和菜單。 網頁被劃分為四個部分:Header、Menu、Footer和Content。對于同一站點的所有Web頁面,Header、Menu和Footer部分的內容相同,僅僅Content部分的內容不相同。如果采用基本的JSP語句來編寫所有的Web頁面,顯然會導致大量的重復編碼,增加開發和維護成本。
                Tiles框架為創建Web頁面提供了一種模板機制,它能將網頁的布局和內容分離。它允許先創建模板,然后在運行時動態地將內容插入到模板中。Tiles框架建立在JSP的include指令的基礎上,但它提供了比JSP的include指令更強大的功能。
            Tiles框架具有如下特性:
            創建可重用的模板
            動態構建和裝載頁面
            定義可重用的Tiles組
            支持國際化
            Tiles框架包含以下內容:
            Tiles標簽庫
            Tiles組件的配置文件
            TilesPlugIn插件
             
            采用JSP include指令來創建復合式頁面,已經在提高代碼可重用性方面邁出了正確的一步。通過JSP include指令把這些相同內容包含進來,這樣提高了代碼的可重用性。但是JSP include指令不能完全避免代碼冗余。
              Tiles標簽庫的tiles:insert標簽和JSP include指令具有相同的功能,也能把其他的JSP頁面插入到當前頁面中。例如,以下兩條語句的作用是相同的:

             


            <jsp:include page="indexContent.jsp"/>
            <tiles:insert page="indexContent.jsp" flush="true"/>


                   標簽的page屬性指定被插入的JSP文件,flush屬性的可選值包括true和false,當flush屬性為true,表示在執行插入操作之前,先調用當前頁面的輸出流的flush()方法。
                  用tiles:insert標簽取代JSP include指令來創建復合式頁面,代碼僅有稍微的差別,兩者的利弊也很相似。單純使用tiles:insert標簽來創建復合式頁面,還沒有充分發揮Tiles框架的優勢。
                 通俗的講,Tiles模板是一種描述頁面布局的JSP頁面。Tiles模板僅僅定義Web頁面的樣式,而不指定內容。在Web應用運行時,才把特定內容插入到模板頁面中。同一模板可以被多個Web頁面共用。
                 使用模板,可以輕松的實現Web應用的所有頁面保持相同的外觀和布局,無需為每個頁面硬編碼。在一個應用中,大多數頁面使用同一模板,某些頁面可能需要不同的外觀,使用其他的模板,因此一個應用可能有一個以上模板。
                   在模板文件layout.jsp中定義了網頁的布局,但沒有指定各部分具體的內容。layout.jsp中包含多個tiles:insert標簽,它的attribute屬性僅僅指定了待插入內容的邏輯名,而沒有指定真正被插入的文件。
                    采用Tiles模板機制,大大提高了代碼的可重用性和可維護性,模板中包含了網頁共同的布局。如果布局發生變化,只需要修改模板文件,無需修改具體的網頁文件。
              Tiles框架允許在專門的XML文件中配置Tiles組件。例如,以下代碼定義了一個名為"index-definition"的Tiles組件,它描述整個index.jsp網頁:

             


            <tiles-definitions>
               <definition name="index-definition" path="/layout.jsp">
                  <put name="sidebar" value="sidebar.jsp"/>
                  <put name="header" value="header.jsp"/>  
                  <put name="content" value="indexContent.jsp"/>  
                  <put name="footer" value="footer.jsp"/>  
               </definition>
            </tiles-definitions>


                definition元素的name屬性指定Tiles組件的名字,path屬性指定Tiles組件使用的模板,definition元素的put子元素用于向模板中插入具體的網頁內容。
                   TilesPlugin插件用于加載Tiles組件的配置文件。在plug-in元素中包含幾個set-property子元素,用于向TilesPlugin插件傳入附加的參數:
                ·definitions-config參數:指定Tiles組件的配置文件,如果有多個配置文件,則它們之間用逗號分隔。
                ·definitions-parser-validate參數:指定XML解析器是否驗證Tiles配置文件,可選值包括true和false,默認值為true。
                      通過Struts Action來調用Tiles組件
                如果Tiles組件代表完整的網頁,可以直接通過Struts Action來調用Tiles組件。例如,如果希望通過Struts Action來調用名為"index-definition"的Tiles組件,可以在Struts配置文件中配置如下Action映射:

             


            <action-mappings>
            <action   path="/index"
                      type="org.apache.struts.actions.ForwardAction"
                      parameter="index-definition">
             </action>
            </action-mappings>


                接下來通過瀏覽器訪問 http://localhost:8080/tilestaglibs/index.do,該請求先被轉發到ForwardAction,ForwardAction再把請求轉發給名為"index-definition"的Tiles組件,最后在瀏覽器端,用戶將看到和index.jsp相同的頁面。
                通過Struts Action來調用Tiles組件,可以充分發揮Struts框架負責流程控制的功能。此外,可以減少JSP文件的數目。例如,如果直接通過Struts Action來調用名為"index-definition"的Tiles組件,就不必再創建index.jsp文件。
                 Tiles組件是一種可重用的組件。可以象搭積木一樣,把簡單的Tiles組件組裝成復雜的Tiles組件。
            可以利用Tiles組件的可擴展特性來進一步消除冗余代碼。解決方法為先定義一個包含這兩個Tiles組件的共同內容的父類Tiles組件,命名為"base-definition",然后再讓"index-definition"和"product-definition"這兩個Tiles組件繼承這個父類組件。
                一個Tiles組件繼承另一個Tiles組件的語法如下,其中definition元素的extends屬性指定被擴展的父類Tiles組件:

             
            <definition name="index-definition" extends="base-definition">
             
            文章出處:飛諾網(www.diybl.com):http://www.diybl.com/course/1_web/webjs/20071226/95178.html

            久久SE精品一区二区| 一本久久精品一区二区| 亚洲综合婷婷久久| 国产精品内射久久久久欢欢| 区亚洲欧美一级久久精品亚洲精品成人网久久久久 | 青青热久久国产久精品| 人妻精品久久久久中文字幕| 精品少妇人妻av无码久久| 久久99精品久久久久久9蜜桃| 久久国产劲爆AV内射—百度| 久久美女网站免费| 亚洲中文字幕久久精品无码APP | 久久无码国产专区精品| 国产麻豆精品久久一二三| 日韩久久无码免费毛片软件 | 色综合久久无码五十路人妻| 国产精品一区二区久久精品无码 | 亚洲狠狠久久综合一区77777| 狠狠色丁香久久婷婷综合蜜芽五月| 久久91精品国产91久久麻豆| 伊人久久久AV老熟妇色| 欧美麻豆久久久久久中文| 人人狠狠综合久久亚洲88| 久久精品国产第一区二区三区| 麻豆久久久9性大片| 久久精品无码一区二区日韩AV| 热久久国产精品| 亚洲欧美精品伊人久久| 久久久久久久久久久久中文字幕| 美女久久久久久| 香蕉99久久国产综合精品宅男自 | 久久综合综合久久狠狠狠97色88| 日韩精品久久久久久久电影蜜臀| 亚洲欧美国产精品专区久久 | 狠狠狠色丁香婷婷综合久久五月 | 88久久精品无码一区二区毛片 | 日本精品久久久久影院日本| 欧美午夜精品久久久久久浪潮| 国内精品伊人久久久久影院对白 | 新狼窝色AV性久久久久久| 亚洲精品无码久久一线|