1
我有一个形式与selectOneMenu
,当我选择第三个“Visualizar todos los archivos”我想渲染一个<t:tree2>
。所有这些都是使用Ajax在selectOneMenu
中的值发生更改时呈现组件。阿贾克斯渲染的战斧t: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>
我缺少什么?
在此先感谢。
有什么'uploadFile' bean的范围是什么?您已经在''的'rendered'属性中错过了拼写错误。 –
BalusC
UploadFile bean是ViewScoped。 (检查拼写错误)。 – BRabbit27
是的,这确实是错别字,它并没有使它成功。 – BRabbit27