我正在使用Primefaces 5.0。我有一个selectOneMenu,里面有ajax监听器:选择/点击Primefaces selectOneMenu ajax事件
<p:selectOneMenu value="#{mybean.myselection}" >
<f:selectItems value="#{mybean.mylist}" />
<p:ajax listener="#{mybean.test}" />
</p:selectOneMenu>
每当值改变时都会调用监听器。这工作正常。但是我还需要一个像“select”或“click”这样的事件,当点击选定的项目时也会触发一个动作。
我在PF UserGuide中找不到活动。是否有捷径可寻?
编辑: 添加Javascript函数。
<h:form>
<p:selectOneMenu value="#{mybean.myselection}" widgetVar="mySelect">
<f:selectItems value="#{mybean.mylist}" />
<p:ajax listener="#{mybean.test}" />
</p:selectOneMenu>
<h:form>
<script>
//<![CDATA[
$(document)
.ready(
function() {
PF('mySelect').selectItem = function(item,
silent) {
var selectedOption = this.options.eq(this
.resolveItemIndex(item)), currentOption = this.options
.filter(':selected'), shouldChange = null;
if (this.cfg.editable) {
shouldChange = (selectedOption.text() != this.label
.val());
} else {
shouldChange = true;
}
if (shouldChange) {
this.highlightItem(item);
this.input.val(selectedOption.val())
this.triggerChange();
if (this.cfg.editable) {
this.customInput = false;
}
}
if (!silent) {
this.focusInput.focus();
}
if (this.panel.is(':visible')) {
this.hide();
}
}
})
//]]>
</script>
对不起,延迟回复。我添加了您的JavaScript,但它不起作用。你能给我一个提示吗? – veote 2014-09-25 05:49:39
它没有什么意义?我的意思是你在控制台中有任何错误?或者你没有太多关于JavaScript的想法? – 2014-09-25 06:57:56
啊好吧我已经看到你的更新...如果你有任何错误,你会看看控制台吗? – 2014-09-25 07:02:22