2011-11-15 2 views
1

フォームはselectOneMenuです.3番目の "Visualizar todos los archivos"を選択すると、<t:tree2>をレンダリングします。 selectOneMenuで値が変更されたときにコンポーネントをレンダリングするためにAjaxを使用しています。TomahawkのAjaxレンダリング:tree2は最初のノードのみをレンダリングし、子ノードは展開されません

何が起こっているのは、ツリーの最初のノードだけがレンダリングされ、フォルダの隣にある+記号をクリックすると、まったく展開されません。

これは私のコードです:

<h:form id="menuForm" enctype="multipart/form-data"> 
     <h:outputLabel for="option" value="Acciones disponibles: " /> 
     <h:selectOneMenu id="option" 
         value="#{uploadFile.option}"> 
      <f:selectItem itemLabel="Seleccione una opción..." itemValue="null" /> 
      <f:selectItems value="#{uploadFile.options}" /> 
      <f:ajax render="@form" execute="@form" /> 
     </h:selectOneMenu> 

     <h:panelGrid id="dataLoad" columns ="3" 
        rendered="#{uploadFile.option == 'Cargar información completa.' || 
           uploadFile.option == 'Cargar solo información errónea.'}"> 
      <h:outputLabel for="upfile" value="Archivo: " /> 
      <t:inputFileUpload id="upfile" 
           value="#{uploadFile.upFile}" /> 
      <h:panelGroup/> 
      <h:panelGroup/> 
      <h:commandButton value="Continuar" 
          onclick="return confirmation()" 
          action="#{uploadFile.upload}" /> 
     </h:panelGrid> 

     <h:panelGrid id="listFiles" columns="3" 
        rendered="#{uploadFile.option == 'Visualizar todos los archivos.'}"> 
      <t:tree2 id="tree" value="#{listFiles.treeRoot}" 
        var="node" varNodeToggler="t" > 
       <f:facet name="folder"> 
        <h:panelGroup> 
         <f:facet name="expand"> 
          <t:graphicImage value="images/folderOpen.png" 
              rendered="#{t.nodeExpanded}}" 
              border="0" /> 
         </f:facet> 
         <f:facet name="collapse"> 
          <t:graphicImage value="images/folderClose.png" 
              rendere="#{t.nodeExpanded}}" 
              border="0" /> 
         </f:facet> 
         <h:outputText value="#{node.description}" 
             styleClass="nodeFolder" /> 
        </h:panelGroup> 
       </f:facet> 
       <f:facet name="file"> 
        <h:panelGroup> 
         <h:commandLink action="#{listFiles.download(node.identifier)}"> 
          <t:graphicImage value="images/file.png" border="0" /> 
          <h:outputText value="#{node.description}" /> 
         </h:commandLink> 
        </h:panelGroup> 
       </f:facet> 
      </t:tree2> 
     </h:panelGrid> 
    </h:form> 

私は何をしないのですか?

ありがとうございます。

+1

'uploadFile' Beanのスコープは何ですか? ''と ' 'の両方の' rendered'属性の入力ミスです。 – BalusC

+0

UploadFile BeanはViewScopedです。 (タイプミスのチェック)。 – BRabbit27

+0

はい、実際には機能しなかったのは誤植でした。 – BRabbit27

答えて

1

コードに入力ミスがあります。それがされている必要があります

<t:graphicImage value="images/folderOpen.png" 
       rendered="#{t.nodeExpanded}}" 
       border="0" /> 

<t:graphicImage value="images/folderClose.png" 
       rendere="#{t.nodeExpanded}}" 
       border="0" /> 

::次のコンポーネントのrendered属性を注意

<t:graphicImage value="images/folderOpen.png" 
       rendered="#{t.nodeExpanded}" 
       border="0" /> 

<t:graphicImage value="images/folderClose.png" 
       rendered="#{t.nodeExpanded}" 
       border="0" /> 
関連する問題