同じフォームに rich:pickList または rich:orderingList がある場合、ah:form 内の a4j:ajax タグに問題があります。何が起こるかというと、ajax リクエストが完了せず、バッキング Bean のリスナー メソッドが起動されません。onbegin イベントは発生しますが、oncomplete は発生しません。これは本当に奇妙です。
コンポーネントを rich:select などに変更すると、ajax は正常に動作します。
これが私のコードの一部です。
<!DOCTYPE composition PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN"
"http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<ui:composition xmlns="http://www.w3.org/1999/xhtml"
xmlns:s="http://jboss.org/schema/seam/taglib"
xmlns:ui="http://java.sun.com/jsf/facelets"
xmlns:f="http://java.sun.com/jsf/core"
xmlns:h="http://java.sun.com/jsf/html"
xmlns:a="http://richfaces.org/a4j"
xmlns:rich="http://richfaces.org/rich"
xmlns:a4j="http://richfaces.org/a4j"
template="layout/template.xhtml">
<ui:define name="body">
<h:form id="perfil" styleClass="edit">
<rich:panel>
<a4j:outputPanel id="outputPanel">
<s:decorate id="nomeField" template="layout/edit.xhtml">
<ui:define name="label">Nome</ui:define>
<h:inputText id="nome" size="100" maxlength="100"
value="#{perfilHome.instance.nome}">
<a4j:ajax event="blur" onbegin="alert('begin');"
oncomplete="alert('complete');" bypassUpdates="true" render="outputPanel"
listener="#{perfilHome.test()}" />
</h:inputText>
</s:decorate>
</a4j:outputPanel>
<s:decorate id="descricaoField" template="layout/edit.xhtml">
<ui:define name="label">Descrição</ui:define>
<h:inputTextarea id="descricao" required="true" cols="100" rows="4" value="#{perfilHome.instance.descricao}" />
</s:decorate>
<s:decorate id="permissoesField" template="layout/edit.xhtml">
<rich:pickList required="true" styleClass="picklist" style="border: none; background: transparent;"
collectionType="java.util.ArrayList" immediate="false"
id="permissaoPickList"
value="#{perfilHome.instance.permissoes}"
listWidth="165px" listHeight="100px" orderable="true">
<f:selectItems id="permissoesItens" value="#{perfilHome.listarPermissoes()}" var="permissao"
itemValue="#{permissao}" itemLabel="#{permissao.nome}" />
<s:convertEntity />
</rich:pickList>
</s:decorate> </rich:panel>
<div class="actionButtons">
<h:commandButton id="save" value="Salvar"
action="#{perfilHome.persist}" disabled="#{!perfilHome.wired}"
rendered="#{!perfilHome.managed}">
<s:conversationId />
</h:commandButton>
<h:commandButton id="update" value="Salvar"
action="#{perfilHome.update}" rendered="#{perfilHome.managed}">
<s:conversationId />
</h:commandButton>
<h:commandButton id="delete" value="Deletar"
action="#{perfilHome.remove}" immediate="true"
rendered="#{perfilHome.managed}" /> </div>
</h:form>
<s:button id="cancelEdit" value="Cancelar" propagation="end"
view="/Perfil.xhtml" rendered="#{perfilHome.managed}" />
<s:button id="cancelAdd" value="Cancelar" propagation="end"
view="/#{empty perfilFrom ? 'PerfilList' : perfilFrom}.xhtml"
rendered="#{!perfilHome.managed}" />
</ui:define>
</ui:composition>
私が言ったように、私はpickListとorderingListでのみこの動作を観察しました。そんな悩みを抱えた人はいますか?
2 番目の質問は、両方の s:button をフォーム内に配置すると、ajax も起動されないということです。それについての説明はありますか?
JSF 2.1.14 + RichFaces 4.2.3 + Seam 2.3.0 を使用しています
ありがとう
2013 年 1 月 14 日更新。以前は気付かなかったスタック トレースを観察しました。ビューステートが失われていると思います。多くのコンポーネントで再度テストしましたが、pickList と OrderingList に問題があることに気付きました。
Exception during request processing:
Caused by java.lang.NullPointerException with message: ""
com.sun.faces.context.PartialViewContextImpl.createPartialResponseWriter(PartialViewContextImpl.java:441)
com.sun.faces.context.PartialViewContextImpl.access$300(PartialViewContextImpl.java:71)
com.sun.faces.context.PartialViewContextImpl$DelayedInitPartialResponseWriter.getWrapped(PartialViewContextImpl.java:582)
javax.faces.context.PartialResponseWriter.startDocument(PartialResponseWriter.java:115)
com.sun.faces.context.AjaxExceptionHandlerImpl.handlePartialResponseError(AjaxExceptionHandlerImpl.java:199)
com.sun.faces.context.AjaxExceptionHandlerImpl.handle(AjaxExceptionHandlerImpl.java:123)
com.sun.faces.lifecycle.Phase.doPhase(Phase.java:119)
com.sun.faces.lifecycle.RestoreViewPhase.doPhase(RestoreViewPhase.java:116)
com.sun.faces.lifecycle.LifecycleImpl.execute(LifecycleImpl.java:118)
javax.faces.webapp.FacesServlet.service(FacesServlet.java:593)
org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:329)
org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:248)
org.jboss.seam.servlet.SeamFilter$FilterChainImpl.doFilter(SeamFilter.java:83)
org.jboss.seam.web.LoggingFilter.doFilter(LoggingFilter.java:60)
org.jboss.seam.servlet.SeamFilter$FilterChainImpl.doFilter(SeamFilter.java:69)
org.jboss.seam.web.IdentityFilter.doFilter(IdentityFilter.java:40)
org.jboss.seam.servlet.SeamFilter$FilterChainImpl.doFilter(SeamFilter.java:69)
org.jboss.seam.web.MultipartFilter.doFilter(MultipartFilter.java:90)
org.jboss.seam.servlet.SeamFilter$FilterChainImpl.doFilter(SeamFilter.java:69)
org.jboss.seam.web.ExceptionFilter.doFilter(ExceptionFilter.java:64)
org.jboss.seam.servlet.SeamFilter$FilterChainImpl.doFilter(SeamFilter.java:69)
org.jboss.seam.web.RedirectFilter.doFilter(RedirectFilter.java:45)
org.jboss.seam.servlet.SeamFilter$FilterChainImpl.doFilter(SeamFilter.java:69)
org.jboss.seam.web.HotDeployFilter.doFilter(HotDeployFilter.java:53)
org.jboss.seam.servlet.SeamFilter$FilterChainImpl.doFilter(SeamFilter.java:69)
org.jboss.seam.servlet.SeamFilter.doFilter(SeamFilter.java:158)
org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:280)
org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:248)
org.apache.catalina.core.StandardWrapperValve.invoke(StandardWrapperValve.java:275)
org.apache.catalina.core.StandardContextValve.invoke(StandardContextValve.java:161)
org.apache.catalina.authenticator.AuthenticatorBase.invoke(AuthenticatorBase.java:397)
org.jboss.as.jpa.interceptor.WebNonTxEmCloserValve.invoke(WebNonTxEmCloserValve.java:50)
org.jboss.as.web.security.SecurityContextAssociationValve.invoke(SecurityContextAssociationValve.java:153)
org.apache.catalina.core.StandardHostValve.invoke(StandardHostValve.java:155)
org.apache.catalina.valves.ErrorReportValve.invoke(ErrorReportValve.java:102)
org.apache.catalina.core.StandardEngineValve.invoke(StandardEngineValve.java:109)
org.apache.catalina.connector.CoyoteAdapter.service(CoyoteAdapter.java:368)
org.apache.coyote.http11.Http11Processor.process(Http11Processor.java:877)
org.apache.coyote.http11.Http11Protocol$Http11ConnectionHandler.process(Http11Protocol.java:671)
org.apache.tomcat.util.net.JIoEndpoint$Worker.run(JIoEndpoint.java:930)
java.lang.Thread.run(Thread.java:722)