我正在使用JSF 2.2.9,我有以下dataTable和按钮:
<h:commandButton id="commandButtonRemoverSelected"
actionListener="#{managedBeanName.removeSelected()}"
class="btn btn-primary" value="Sim">
</h:commandButton>
<h:dataTable var="bean" value="#{managedBeanName.beans}" styleClass="table table-hover"
binding="#{managedBeanName.dataTable}">
<h:column headerClass="smallColumn">
<f:facet name="header">
<h:selectBooleanCheckbox valueChangeListener="#{managedBeanName.selectAll}">
<f:ajax execute="@form" render="@all" />
</h:selectBooleanCheckbox>
</f:facet>
<h:selectBooleanCheckbox value="#{managedBeanName.registrosSelecionados[bean]}" />
</h:column>
</h:dataTable>
按钮"命令按钮删除已选择"只需在第二次单击时调用 actionListener。当我从datatabe中删除以下行时,一切正常(第一次单击时调用命令按钮):
<h:selectBooleanCheckbox value="#{managedBeanName.registrosSelecionados[bean]}" />
所以,我的托管Bean有一个名为"registrosSelecionados"的MAP,它应该存储一对"Bean,Boolean"。看:
private Map<Bean, Boolean> registrosSelecionados = new HashMap<Bean, Boolean>();
解决方案
我用解决方法解决了这个问题,我会分享这个:
1 - 我注意到每个第一个命令按钮点击'getRegistrosSelecionados()'被调用,而actionListener没有。所以我想象JSF正在处理getRegistrosSelecionados()而不处理actionListener,我不知道为什么,这是真正的问题。在第二次单击中,将处理 actionListener,因为在第一次单击时,所有复选框都已发送到 ManagedBean。
2 - 因此,我的解决方法是强制每次单击复选框调用JSF请求,而不是等待命令按钮提交。这样,当单击命令按钮时,所有复选框都已处理。
<h:selectBooleanCheckbox value="#{cc.attrs.managedBeanName.registrosSelecionados[bean]}">
<f:ajax execute="@this" render="@this" />
</h:selectBooleanCheckbox>
我的复选框收到ajax仅执行自身并呈现自身,当我单击命令按钮时,我只需要执行命令按钮并再次渲染表单:
<h:commandButton id="commandButtonRemoverSelected"
actionListener="#{cc.attrs.managedBeanName.removeSelected()}"
class="btn btn-primary" value="Sim">
<f:ajax execute="@this" render="@form" />
</h:commandButton>
此解决方法对我有用,因为我没有找到更好的解决方案。