在我的应用程序中,我有以下代码:
<h:form>
<h:outputLabel for="type" style="font-weight: bold" value="*Type: " />
<h:selectOneMenu label="type" id="type" binding="#{type}">
<f:ajax execute="type" render="text article video" />
<f:selectItem itemValue="article" itemLabel="Article" />
<f:selectItem itemValue="video" itemLabel="Video" />
</h:selectOneMenu>
<p:message for="type" />
<h:outputText id="text" value="#{type.value}" />
<h:panelGrid id="article" rendered="#{type.value == 'article'}" >
...
</h:panelGrid>
<h:panelGrid id="video" rendered="#{type.value == 'video'}" >
...
</h:panelGrid>
</h:form>
当我从菜单中选择一个选项时,我确信已触发Ajax调用,因为<h:outputText>
已正确呈现type.value
。但是,<h:panelGrid>
都没有呈现。
如果你能告诉我应该如何解决这个问题,我将非常感激。
致以最诚挚的问候,
James Tran
答案 0 :(得分:2)
JavaScript / Ajax无法更新JSF未呈现的HTML元素。将其包装在始终呈现的组件中,然后更新它。
<h:form>
<h:outputLabel for="type" style="font-weight: bold" value="*Type: " />
<h:selectOneMenu label="type" id="type" binding="#{type}">
<f:ajax execute="type" render="text grids" />
<f:selectItem itemValue="article" itemLabel="Article" />
<f:selectItem itemValue="video" itemLabel="Video" />
</h:selectOneMenu>
<p:message for="type" />
<h:outputText id="text" value="#{type.value}" />
<h:panelGroup id="grids">
<h:panelGrid id="article" rendered="#{type.value == 'article'}" >
...
</h:panelGrid>
<h:panelGrid id="video" rendered="#{type.value == 'video'}" >
...
</h:panelGrid>
</h:panelGroup>
</h:form>