Jåc*_*cob 19 jsf primefaces jsf-2
我正在使用Primefaces 3.4.2.
我的JSF页面中有以下内容
<p:selectOneMenu id="emp" value="#{mymb.emp.employeeName}"
valueChangeListener="#{mymb.handleChange}"
required="true"
style="width: 150px;">
<f:selectItem noSelectionOption="true"
itemLabel="Please Select"/>
<f:selectItems value="#{mymb.employeeList}" var="emp"
itemLabel="#{emp.employeeName}"
itemValue="#{emp.employeeNumber}"/>
<p:ajax update="sublist"/>
</p:selectOneMenu>
Run Code Online (Sandbox Code Playgroud)
并在ManagedBean中
public void handleChange(ValueChangeEvent event){
System.out.println("here "+event.getNewValue());
}
Run Code Online (Sandbox Code Playgroud)
问题是valueChangeListener
没有触发,即handleChange
方法没有被调用.我尝试了以下,但它也没有工作.
<p:ajax update="sublist" listener="#{mymb.handleChange}" />
Run Code Online (Sandbox Code Playgroud)
单独的JSF页面:
<ui:composition template="/templates/layout.xhtml"
xmlns="http://www.w3.org/1999/xhtml"
xmlns:f="http://java.sun.com/jsf/core"
xmlns:h="http://java.sun.com/jsf/html"
xmlns:ui="http://java.sun.com/jsf/facelets"
xmlns:p="http://primefaces.org/ui">
<ui:define name="content">
<h:head>
</h:head>
<h:body>
<h:form id="form">
<p:panelGrid columns="6">
<h:outputLabel value="Employees" for="employees" />
<p:selectOneMenu id="employees"
value="#{mymb.employeesList}"
required="true">
<f:selectItems value="#{mymb.employeesList}" var="emp"
itemLabel="#{emp.employeeName}" />
<p:ajax listener="#{mymb.handleChange}" />
</p:selectOneMenu>
</p:panelGrid>
</h:form>
</h:body>
</ui:define>
</ui:composition>
Run Code Online (Sandbox Code Playgroud)
Mr.*_*mes 50
如果要使用valueChangeListener
,则每次选择新选项时都需要提交表单.像这样的东西:
<p:selectOneMenu value="#{mymb.employee}" onchange="submit()"
valueChangeListener="#{mymb.handleChange}" >
<f:selectItems value="#{mymb.employeesList}" var="emp"
itemLabel="#{emp.employeeName}" itemValue="#{emp.employeeID}" />
</p:selectOneMenu>
public void handleChange(ValueChangeEvent event){
System.out.println("New value: " + event.getNewValue());
}
Run Code Online (Sandbox Code Playgroud)
或者,如果你想使用<p:ajax>
它,它应该是这样的:
<p:selectOneMenu value="#{mymb.employee}" >
<p:ajax listener="#{mymb.handleChange}" />
<f:selectItems value="#{mymb.employeesList}" var="emp"
itemLabel="#{emp.employeeName}" itemValue="#{emp.employeeID}" />
</p:selectOneMenu>
private String employeeID;
public void handleChange(){
System.out.println("New value: " + employee);
}
Run Code Online (Sandbox Code Playgroud)
有一点需要注意的是,在你的示例代码中,我看到了value
你的属性<p:selectOneMenu>
就是#{mymb.employeesList}
它是相同value
的<f:selectItems>
.在value
你的<p:selectOneMenu>
应该是类似我的例子高于该点的一个员工,没有员工的名单.
Mat*_*ndy 16
valueChangeListener
如果您对旧值和新值都感兴趣,那么这是必要的.
如果您只对新值感兴趣,使用<p:ajax>
或者<f:ajax>
是更好的选择.
有几个可能的原因,为什么ajax调用不起作用.首先,您应该更改处理程序方法的方法签名:删除参数.然后,您可以直接访问托管bean变量:
public void handleChange(){
System.out.println("here "+ getEmp().getEmployeeName());
}
Run Code Online (Sandbox Code Playgroud)
当时,调用侦听器,已设置新值.(注意,我隐含地假设el表达式mymb.emp.employeeName
由相应的getter/setter方法正确支持.)
小智 11
另一种解决方案是混合valueChangeListener,ajax和process:
<p:selectManyCheckbox id="employees" value="#{employees}" columns="1" layout="grid" valueChangeListener="#{mybean.fireSelection}" >
<f:selectItems var="employee" value="#{employeesSI}" />
<p:ajax event="valueChange" immediate="true" process="@this"/>
</p:selectManyCheckbox>
Run Code Online (Sandbox Code Playgroud)
mybean中的方法只是:
public void fireSelection(ValueChangeEvent event) {
log.debug("New: "+event.getNewValue()+", Old: "+event.getOldValue());
}
Run Code Online (Sandbox Code Playgroud)
像这样,valueChangeEvent很轻!
PS:与PrimeFaces 5.0一起使用
小智 10
<p:ajax listener="#{my.handleChange}" update="id of component that need to be rerender after change" process="@this" />
import javax.faces.component.UIOutput;
import javax.faces.event.AjaxBehaviorEvent;
public void handleChange(AjaxBehaviorEvent vce){
String name= (String) ((UIOutput) vce.getSource()).getValue();
}
Run Code Online (Sandbox Code Playgroud)
可以定义为f:ajax
服装。
即
<p:selectOneMenu id="employees" value="#{mymb.employeesList}" required="true">
<f:selectItems value="#{mymb.employeesList}" var="emp" itemLabel="#{emp.employeeName}" />
<f:ajax event="valueChange" listener="#{mymb.handleChange}" execute="@this" render="@all" />
</p:selectOneMenu>
Run Code Online (Sandbox Code Playgroud)
event:可以是正常的DOM事件,例如click
或valueChange
execute:这是组件的客户机ID的空格分隔列表,这些客户机ID将参与请求处理生命周期的“执行”部分。
render:将参与请求处理生命周期的“ render”部分的组件的clientIds。完成操作后,您可以定义应刷新的组件。可以添加标识,IDLIST或这些关键字:@this
,@form
,@all
,@none
。
您可以通过以下链接访问整个属性列表:http : //docs.oracle.com/javaee/6/javaserverfaces/2.1/docs/vdldocs/facelets/f/ajax.html
归档时间: |
|
查看次数: |
171385 次 |
最近记录: |