Jsf 2 f:ajax方法在jsf页面加载时被调用
我有一个简单的3行jsf页面和一个支持bean。我正在使用页面中的命令按钮。Onclick事件我称之为ajax。其中ajax方法将输出文本组件添加到子对象。现在的问题是。输出文本组件是在加载页面时呈现的,而不是在单击页面时呈现的Jsf 2 f:ajax方法在jsf页面加载时被调用,jsf-2,Jsf 2,我有一个简单的3行jsf页面和一个支持bean。我正在使用页面中的命令按钮。Onclick事件我称之为ajax。其中ajax方法将输出文本组件添加到子对象。现在的问题是。输出文本组件是在加载页面时呈现的,而不是在单击页面时呈现的 <html xmlns="http://www.w3.org/1999/xhtml" xmlns:h="http://java.sun.com/jsf/html" xmlns:f="http://java.sun.com/jsf/core"
<html xmlns="http://www.w3.org/1999/xhtml"
xmlns:h="http://java.sun.com/jsf/html"
xmlns:f="http://java.sun.com/jsf/core">
<h:head>
<title>Facelet Title</title>
</h:head>
<h:body>
<h:form>
<h:commandButton id="button1" action="return false" value="Submit">
<f:ajax execute="#{bb.method1()}" render="@form" transient="true" event="click" />
</h:commandButton>
</h:form>
</h:body>
</html>
点击按钮firebug显示状态200 OK。。但是我在页面上看不到任何更改,
execute
属性应该指的是输入组件的客户机ID的空间分隔集合,需要在ajax提交期间进行处理。当视图被渲染并且绑定到它的任何方法被立即调用时,将计算该属性
您应该使用listener
属性
<f:ajax listener="#{bb.method1()}" render="@form" transient="true" event="click" />
render
属性也是如此
另见:
<f:ajax listener="#{bb.method1()}" render="@form" transient="true" event="click" />