如何使用<h:selectbooleancheckbox>选择多行<h:datatable> </h:selectbooleancheckbox> </h:datatable>

时间:2011-09-01 04:40:45

标签: jsf datatable multipleselection selectbooleancheckbox

我使用<h:dataTable>列出数据库中的数据。我们在页面中有很多记录,现在我想选择多行记录,每行都有一个复选框。我怎样才能做到这一点?

1 个答案:

答案 0 :(得分:6)

我假设您的实体经过精心设计,具有唯一的技术标识符,例如来自数据库的自动增量序列。

public class Entity {

    private Long id;
    // ...
}

如果没有,您需要添加它。

然后,将Map<Long, Boolean>属性添加到与表绑定的bean中。

private Map<Long, Boolean> checked = new HashMap<Long, Boolean>();

(preinitialization也可以在(post)构造函数中发生,请你选择,至少JSF不会为你做;哦,也给它一个getter,不需要setter)

然后,添加一个带有复选框的列,该复选框按实体ID映射到布尔值作为键。

<h:dataTable value="#{bean.entities}" var="entity">
    <h:column>
        <h:selectBooleanCheckbox value="#{bean.checked[entity.id]}" />
    </h:column>
    ...
</h:dataTable>
<h:commandButton value="Delete" action="#{bean.delete}" />

现在,在与删除按钮相关联的操作方法中,您可以按如下方式收集和删除选中的项目:

public void delete() {
    List<Entity> entitiesToDelete = new ArrayList<Entity>();

    for (Entity entity : entities) {
        if (checked.get(entity.getId())) {
            entitiesToDelete.add(entity);
        }
    }

    entityService.delete(entitiesToDelete);
    checked.clear();
    loadEntities();
}