[英]Richfaces a4j:commandButton not working when enabled after a ajax response
[英]RichFaces rich:panelMenu stops working when a4j:include'd
從這個以前問的問題 ,我注意到,當我移動一個rich:panelMenu
(這在當正常工作index.jsp
頁)到another.jsp
,然后包括在index.jsp
使用a4j:include
標簽,將rich:panelMenu
功能停止工作。
這是錯誤嗎?
編輯1
為了響應代碼並經過一些隔離測試,該問題似乎是由於來自panelMenu的rich:tabPanel
另一個選項卡中的rich:tabPanel
rich:dataTable
共存。
如果我的index.jsp
包含使用演示代碼(Bean中的inc)的默認簡單panelMenu,則它將按預期工作:
<f:view>
<rich:page pageTitle="title" markupType="xhtml">
<h:outputText id="setup" value="#{MyBacking.setup}" />
<rich:toolBar height="35" itemSeparator="line">
<rich:toolBarGroup location="left">
<a4j:form>
<a4j:outputPanel id="panel">
<h:outputText style="text-align: center" value="Node Select " />
<h:selectOneMenu id="nodes" value="#{MyBacking.chosenNode}">
<f:selectItems value="#{MyBacking.nodes}" />
</h:selectOneMenu>
<a4j:commandButton value="Retrieve"
reRender="panel,contentPanel"
onclick="this.disabled=true" oncomplete="this.disabled=false" />
</a4j:outputPanel>
</a4j:form>
</rich:toolBarGroup>
</rich:toolBar>
<!-- added start -->
<h:form id="form">
<h:panelGrid columns="2" width="100%">
<rich:panelMenu style="width:200px" mode="ajax"
iconExpandedGroup="disc" iconCollapsedGroup="disc"
iconExpandedTopGroup="chevronUp" iconGroupTopPosition="right"
iconCollapsedTopGroup="chevronDown">
<rich:panelMenuGroup label="Group 1">
<rich:panelMenuItem label="Item 1.1"
action="#{PanelMenu.updateCurrent}">
<f:param name="current" value="Item 1.1" />
</rich:panelMenuItem>
</rich:panelMenuGroup>
</rich:panelMenu>
<rich:panel bodyClass="rich-laguna-panel-no-header">
<a4j:outputPanel ajaxRendered="true">
<h:outputText value="||#{PanelMenu.current}|| selected"
id="current" />
</a4j:outputPanel>
</rich:panel>
</h:panelGrid>
</h:form>
<!-- added end -->
<rich:panel>
<h:panelGroup layout="block" id="contentPanel">
<a4j:include viewId="#{MyBacking.viewId}">
<f:param name="targetIdParam" value="content" />
</a4j:include>
</h:panelGroup>
</rich:panel>
</rich:page>
</f:view>
但是,如果我從該文件中刪除添加的panelMenu
並將其粘貼到外部jsp頁面的tabPanel
中的單獨選項卡中,則在上面的index.jsp
是a4j:include
d,在加載時, panelMenu
拒絕工作(輸出在日志或控制台中沒有顯示任何內容),而在我的標簽集的另一個標簽中,有一個rich:dataTable
。 使用完全相同的代碼,但是從第二個選項卡中刪除了dataTable
,它們又重新開始工作。
這是帶有panelMenu
的破碎的a4j:include
d文件:
<h:panelGrid columns="1" border="0" style="width: 100%">
<rich:tabPanel switchType="client" rendered="true">
<rich:tab styleClass="tab" label="Node Logs">
<h:panelGrid columns="2" border="0">
<h:graphicImage value="/btn50.png" width="30" height="30"
alt="Logs" />
<h:outputText value="log: #{MyBacking.chosenNode}"
styleClass="pageTitle" />
</h:panelGrid>
<h:form id="form">
<h:panelGrid columns="2" width="100%">
<rich:panelMenu style="width:200px" mode="ajax"
iconExpandedGroup="disc" iconCollapsedGroup="disc"
iconExpandedTopGroup="chevronUp" iconGroupTopPosition="right"
iconCollapsedTopGroup="chevronDown">
<rich:panelMenuGroup label="Group 1">
<rich:panelMenuItem label="Item 1.1"
action="#{PanelMenu.updateCurrent}">
<f:param name="current" value="Item 1.1" />
</rich:panelMenuItem>
</rich:panelMenuGroup>
</rich:panelMenu>
<rich:panel bodyClass="rich-laguna-panel-no-header">
<a4j:outputPanel ajaxRendered="true">
<h:outputText value="||#{PanelMenu.current}|| selected"
id="current" />
</a4j:outputPanel>
</rich:panel>
</h:panelGrid>
</h:form>
</rich:tab>
<rich:tab styleClass="tab" label="Docs">
<rich:dataTable value="#{MyBacking.MyData}">
<rich:column style="text-align:center" width="150px">
</rich:column>
</rich:dataTable>
</rich:tab>
</rich:tabPanel>
</h:panelGrid>
謝謝
當我將taglib聲明重鑄為時,此問題消失了
<ui:composition xmlns="http://www.w3.org/1999/xhtml"
xmlns:ui="http://java.sun.com/jsf/facelets"
xmlns:h="http://java.sun.com/jsf/html"
xmlns:f="http://java.sun.com/jsf/core"
xmlns:a4j="http://richfaces.org/a4j"
xmlns:rich="http://richfaces.org/rich">
而不是使用<% %>
標簽(無論如何它們都不會與facelets一起使用)
並安裝了jsf-facelets-1.1.14.jar
。 到目前為止,根本沒有安裝任何facelets jar!
聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.