我的表格如下:
<h:form>
<h:dataTable value="#{bean.items}" var="item">
<h:column>
<h:selectBooleanCheckbox value="#{item.enabled}" valueChangeListener="#{bean.onchangeEnabled}">
<f:ajax event="change" />
</h:selectBooleanCheckbox>
</h:column>
<h:column>#{item.name}</h:column>
</h:dataTable>
</h:form>
我想在值更改侦听器方法中获得#{item}
或至少#{item.name}
:
public void onchangeEnabled(ValueChangeEvent e) {
// I would like to get #{item.name} here too.
}
我怎样才能做到这一点?
答案 0 :(得分:6)
首先,valueChangeListener
是错误的工具。使用<f:ajax listener>
。其次,event="change"
在复选框/单选按钮的情况下是错误的选择,因为它们的物理值实际上永远不会改变。您应该使用event="click"
,但这是默认设置,因此您可以省略它。
总而言之,正确的初始代码应如下所示:
<h:selectBooleanCheckbox value="#{item.enabled}">
<f:ajax listener="#{bean.onchangeEnabled}" />
</h:selectBooleanCheckbox>
与
public void onchangeEnabled(AjaxBehaviorEvent event) { // Note: event argument is optional.
// ...
}
一旦修复它,那么你可以轻松地利用EL 2.2功能来传递方法参数:
<h:selectBooleanCheckbox value="#{item.enabled}">
<f:ajax listener="#{bean.onchangeEnabled(item)}" />
</h:selectBooleanCheckbox>
与
public void onchangeEnabled(Item item) {
// ...
}
答案 1 :(得分:0)
对于selectBooleanCheckbox,它只对事件点击做出反应,并且应该发布表单。
所以将其添加到复选框
valueChangeListener =“#{mybean.myfunction}”onchange =“submit();”
应该被解雇!