我正在使用Primeface 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>
在ManagedBean中
public void handleChange(ValueChangeEvent event){
System.out.println("here "+event.getNewValue());
}
问题是没有触发valueChangeListener,即没有调用handleChange方法。我尝试了以下方法,但也不起作用。
<p:ajax update="sublist" listener="#{mymb.handleChange}" />
单独的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>
另一种解决方案是混合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>
mybean中的方法只是:
public void fireSelection(ValueChangeEvent event) {
log.debug("New: "+event.getNewValue()+", Old: "+event.getOldValue());
}
像这样,value ChangeEvent很轻!
PS:适用于PrimeFaces 5.0
value eChangeListener
仅在您对新旧值都感兴趣的情况下才是必要的。
如果您只对新值感兴趣,请使用
ajax调用不起作用有几个可能的原因。首先,您应该更改处理程序方法的方法签名:删除参数。然后您可以直接访问托管bean变量:
public void handleChange(){
System.out.println("here "+ getEmp().getEmployeeName());
}
在调用侦听器时,已经设置了新值。(请注意,我隐式假设el表达式
mymb.emp.employeeName
由相应的getter/setter方法正确支持。)
如果您想使用value eChangeListener
,您需要在每次选择新选项时提交表单。类似于这样:
<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());
}
或者,如果您想使用<代码>
<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);
}
需要注意的一点是,在您的示例代码中,我看到您的value
属性
问题内容: 我需要检测选定的选项卡何时更改,并获取其索引。 以下代码可以运行,但是它会触发与当前加载的标签数量相同的次数: 正确的做法是什么?先感谢您。 问题答案: 通过JDK 6 Update 26(Windows 7 64位),以下示例代码仅获得一个事件: 您能在调试器中弄清楚为什么监听器被触发了三遍吗?
问题在于“p:ajax event=“rowDblselect”listener=“#{companyBean.update()}”,当我第一次双击时,方法“update()”被调用了一次(完美!),但在那之后,当我按下命令按钮“button1”并再次双击组件时,“update()”被调用了2次。当我再重复一次时,“update()”被调用了3次。。。这太奇怪了!!我认为,当我用commandBu
问题内容: 我只对属性是否已更改感兴趣,而对新值不感兴趣。 注册一个而不是一个注册是否有利? 我以为对属性的更改会首先使该属性无效并通知所有失效侦听器。仅当已注册更改侦听器或有人请求此属性时,该属性才会被“验证” /重新计算,并且所有更改侦听器都将使用新值进行更新。 由于我对实际值不感兴趣,因此我认为仅侦听无效事件(属性已更改但未重新计算,是某种中间状态)具有性能优势。 问题答案: 您需要为此实现
我有3个下拉列表,第二个必须根据第一个选择的选项加载。第三种是基于第二种选择的。这是页面: 和backbean:
我在滑块上有一个简单的changelistener。谁能解释一下为什么当我点击一个新的位置时,它会被炒3次。在我编写代码将前一个值保存在某个地方以查看它是否真的改变之前,我想知道是否有另一种方法来计算它。第一个跳跳虎显示它原来的样子,下一个显示新值,最后一个重复新值。
我只想根据复选框更改某些输入的所需值。 当我在点击复选框后使用此代码时,标签后没有需要的星号(我的意思是,如果我设置为begging true,星号总是显示,而false星号总是隐藏),第二,它可以在客户端完整完成吗? 重要的是,当我更新整个表单时,它工作正常,但它会清除所有输入,我不想更新所有输入。