寧?kù)o以思遠(yuǎn)

          Java使人內(nèi)心寧?kù)o

          BlogJava 首頁(yè) 新隨筆 聯(lián)系 聚合 管理
            8 Posts :: 0 Stories :: 17 Comments :: 0 Trackbacks
          以前在公司,平臺(tái)組已經(jīng)把組件都給我們開發(fā)好了,對(duì)于界面沒(méi)有花太多的時(shí)間研究。近日想自己做個(gè)小系統(tǒng),還是用比較擅長(zhǎng)的JSF+Hibernate+Spring。考慮Facelet的模板功能,這次想嘗試一下。結(jié)果,一個(gè)Tree2就把我納悶了好一會(huì)。
          從網(wǎng)上找了篇文章,試著依樣畫葫蘆,做了模板頁(yè),分top,left,content三塊布局,left自然就是tree2菜單了。
          首先看一下模板頁(yè):
          template.xthml
          1 <div id="left">
          2          <ui:insert name="left">
          3                     <ui:include src="leftmenu.xhtml"></ui:include>
          4          </ui:insert>
          5 </div>
          6 <div id="content" class="left_content">
          7          <ui:insert name="content">Content</ui:insert>
          8 </div>
          其中左邊菜單:
          leftmenu.xhtml
           1 <t:tree2 id="serverTree" value="#{calendarBean.treeData}" var="node" varNodeToggler="t" clientSideToggle="false" showRootNode="true">
           2                            
           3                             <f:facet name="document">
           4                                 <h:panelGroup>
           5                                     <h:commandLink immediate="true" styleClass="#{t.nodeSelected ? 'documentSelected':'document'}" action="link_page" actionListener="#{t.setNodeSelected}">
           6                                         <t:graphicImage value="/images/document.png" border="0"/>
           7                                         <h:outputText value="#{node.description}"/>
           8                                         <f:param name="docNum" value="#{node.identifier}"/>
           9                                     </h:commandLink>
          10                                 </h:panelGroup>
          11                             </f:facet>
          12  </t:tree2>
          其中backingBean代碼如下,配置有效范圍為session
          public class calendarBean {

              
          private TreeData treeData;

              
          private Date secondDate;

              
          public Date getSecondDate() {
                  
          return secondDate;
              }

              
          public void setSecondDate(Date secondDate) {
                  
          this.secondDate = secondDate;
              }

              
          public TreeData getTreeDate() {
                 
          if (null == treeData) {
                      TreeNode treeData 
          = new TreeNodeBase("foo-folder""Inbox"false);
                      ......
                 }
                 
          return treeData;
          }
          ......
          }

          這里為了方便測(cè)試,故意把commandLink的action指向link_page導(dǎo)航,link_page配置為:
          1 <navigation-rule>
          2     <from-view-id>/treeSample2.xhtml</from-view-id>
          3     <navigation-case>
          4         <from-outcome>link_page</from-outcome>
          5       <to-view-id>/treeSample2link.xhtml</to-view-id>
          6     </navigation-case>
          7   </navigation-rule>
          treeSample2.xhtml和treeSample2link.xhtml分別為兩個(gè)使用了template.xhtml模板的頁(yè)面,顯然它們都用到了菜單。

           運(yùn)行后,首先打開treeSample.xhtml,非常成功,菜單出來(lái)了,而且由于使用了Server端樹,每次打開子節(jié)點(diǎn),都會(huì)提交到服務(wù)器,頁(yè)面刷新后,除了正在操作的節(jié)點(diǎn),其他節(jié)點(diǎn)也都保持原來(lái)的狀態(tài)。

          但是,當(dāng)我點(diǎn)擊節(jié)點(diǎn),跳轉(zhuǎn)到treeSample2link.xhtml時(shí),問(wèn)題出來(lái),所有節(jié)點(diǎn)都折疊起來(lái),而并沒(méi)有保持我原來(lái)頁(yè)面的狀態(tài)。這說(shuō)明從一個(gè)頁(yè)面跳轉(zhuǎn)到另一個(gè)頁(yè)面時(shí),節(jié)點(diǎn)狀態(tài)并沒(méi)有被傳遞過(guò)去。
          有些想不明白,既然backingbean是session的,為什么沒(méi)有記錄節(jié)點(diǎn)的狀態(tài)呢?網(wǎng)上搜了些資料,很少有提到關(guān)于狀態(tài)的。myface的wiki中似乎也找不到類似的問(wèn)題。無(wú)奈之下,只能直接看tree2的代碼,終于發(fā)現(xiàn)了問(wèn)題所在。原來(lái)我有個(gè)TreeState接口存儲(chǔ)節(jié)點(diǎn)狀態(tài)的,而它又是被set到treeModel的,而我的代碼中只使用了treeData,沒(méi)有給它包裝成treeModel。Tree2中提供了treeModel的一個(gè)實(shí)現(xiàn)treeModelBase,直接使用就可以了。于是乎,改一下代碼:
           1 public class calendarBean {
           2   
           3       private TreeModel personTreeModel;
           4   
           5       public TreeModel getPersonTreeModel() {
           6           if (null == personTreeModel) {
           7               TreeNode treeData = new TreeNodeBase("foo-folder""Inbox"false);
           8                  
           9               personTreeModel = new TreeModelBase(treeData);
          10           }
          11         return personTreeModel;
          12     }
          13  
          14 }
          改一下綁定:
          1  <t:tree2 id="serverTree" value="#{calendarBean.persontreeModel}" 
          測(cè)試一下,果然,無(wú)論怎么鏈接,依然保持良好的狀態(tài),呵呵。
          posted on 2009-12-10 00:02 Aaronbamoo 閱讀(1308) 評(píng)論(4)  編輯  收藏

          Feedback

          # re: 終于解決了Tree2的狀態(tài)問(wèn)題 2009-12-10 10:26 99網(wǎng)上書城
          多謝分享  回復(fù)  更多評(píng)論
            

          # re: 終于解決了Tree2的狀態(tài)問(wèn)題 2009-12-11 16:08 愛(ài)美女
          thank you!!!!  回復(fù)  更多評(píng)論
            

          # re: 終于解決了Tree2的狀態(tài)問(wèn)題 2009-12-12 13:27 喜樂(lè)遞女性購(gòu)物
          是獨(dú)領(lǐng)風(fēng)騷的大方  回復(fù)  更多評(píng)論
            

          # re: 終于解決了Tree2的狀態(tài)問(wèn)題 2009-12-15 12:59 aaronbamboo
          @喜樂(lè)遞女性購(gòu)物
          呵呵,見(jiàn)笑了。希望對(duì)遇到同樣問(wèn)題的朋友有所幫助。  回復(fù)  更多評(píng)論
            


          只有注冊(cè)用戶登錄后才能發(fā)表評(píng)論。


          網(wǎng)站導(dǎo)航:
           
          主站蜘蛛池模板: 石阡县| 天全县| 金沙县| 通江县| 蒙阴县| 井冈山市| 大英县| 新疆| 武威市| 铜山县| 偃师市| 贡觉县| 绥德县| 靖州| 常山县| 佛坪县| 德钦县| 类乌齐县| 江门市| 安义县| 龙泉市| 隆尧县| 巴林左旗| 安达市| 望谟县| 丰宁| 古丈县| 光泽县| 边坝县| 秦皇岛市| 陕西省| 辉南县| 通山县| 融水| 原平市| 宜春市| 宜宾县| 绥德县| 乃东县| 华池县| 白水县|