我碰巧不明白为什么如果发生异常我无法收到有关 p:ajaxStatus 的警报
我基本上在 Facelet 页面中包含此代码
<p:ajaxStatus onerror="alert('Error occurred!')" />
<p:commandLink title="Delete" process="@this"
actionListener="#{myBean.deleteData}">
<h:outputText value="Delete" />
</p:commandLink>
在我的 bean 上,我引发了一个异常只是为了测试 ajax 状态
public void deleteData(ActionEvent event) {
throw new CustomException("Testing");
}
我不确定,但 ajax 请求不会触发警报。
我检查了 firebug 并看到了这个 ajax 响应。
<?xml version='1.0' encoding='UTF-8'?>
<partial-response><changes><update id="javax.faces.ViewState"><![CDATA[5240489117331224423:7642972336085906948]]></update></changes></partial-response>
但是当我检查服务器日志时,我看到这个已注册
javax.faces.event.AbortProcessingException: /pages/members.xhtml @208,128 actionListener="#{myBean.deleteData}": com.test.CustomException: Testing
为什么会这样?
Primefaces 3.2/Glassfish/JSF 2.0
最佳答案
来自 p:ajaxStatus
的 Primefaces 3.2 文档:
onerror: Client side callback to execute when an ajax request fails.
在 Firebug 中,您会得到常规的 ajax 响应。所以请求并没有失败。根据我的理解,失败意味着没有响应或响应无效。您看到的是预期的行为。
更新:正如 perissf 所评论的,通常的方法是在操作方法中生成 FacesMessage 并使用 ajax 请求更新 h:messages
标记。
关于ajax - 无法捕获 JSF 2 应用程序上的 ajax 错误,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/10715274/