关于jsf+jboss的复选框

本文探讨了使用JSF框架时遇到的一个关于批量删除的问题,在特定条件下可以实现刷新页面的效果,但在另一些情况下则无法实现。文章详细展示了页面代码及后台处理逻辑,并分析了可能的原因在于a4j按钮组件。
为什么我在删除后刷新页面可以而在提交那个去可以刷新?
页面代码
<h:form>	
<rich:datascroller align="left" for="list" maxPages="20" rendered="#{selectManyAction.count > 20}"/>
<rich:spacer height="10" rendered="#{selectManyAction.count>20}" />
<rich:dataTable width="100%" id="list" rows="20" columnClasses="col" value="#{selectManyAction.selectedDataList}" var="List" columnsWidth="30px,350,90px,120px,40px;" onRowMouseOver="this.style.backgroundColor='#f1f1f1'" onRowMouseOut="this.style.backgroundColor='#{a4jSkin.tableBackgroundColor}'">
<rich:column headerClass="tableheader">
<f:facet name="header">
<h:outputText value="选择" styleClass="colheader"/>
</f:facet>
<h:selectBooleanCheckbox value="#{manySelect.lisMap[List.id]}">

</h:selectBooleanCheckbox>

</rich:column>
<rich:column headerClass="tableheader">
<f:facet name="header">
<h:outputText value="用户名" styleClass="colheader"/>
</f:facet>
<h:outputText value="#{List.userName}" />
</rich:column>
<f:facet name="footer">
<rich:column colspan="2">
<h:selectBooleanCheckbox value="#{selectManyAction.error}">
<a4j:support event="onclick" reRender="datetable" action="#{selectManyAction.setAll()}" />
</h:selectBooleanCheckbox>
<h:commandButton value="Get selected items" action="#{selectManyAction.getSelectedItems}" />

<a4j:commandButton action="#{selectManyAction.removeSelect}" value="删  除" styleClass="signin_right02_center_right_button"/>

</rich:column>
</f:facet>
</rich:dataTable>
</h:form>

下为后台处理类:可能不能刷新原因是:a4j:buttom 的原因吧~!
@Name("selectManyAction")
@Scope(ScopeType.PAGE)
public class SelectManyAction {
// Init --------------------------------------------------------------------------------------
@In
EntityManager entityManager;

@In
ManySelect manySelect;

private List<User> selectedDataList;

private List<User> selectList;
// Actions -----------------------------------------------------------------------------------
private long count;

private boolean error = false;

@SuppressWarnings("unchecked")
@Create
public void init(){
selectedDataList = entityManager.createQuery("select o from User o").getResultList();
for(User user:selectedDataList){
System.out.println("userId======"+user.getId());
}
manySelect.clear();
for(User user:selectedDataList){
manySelect.put(user.getId(), false);
}
Map<Long, Boolean> map = manySelect.getLisMap();
map.entrySet();
}
/*
* 复选框中在同一层中时可以直接从页面传入ID和ID所对应的boolean型保存在一个对象中,当复选框为一层而事件处理为
* 另一层时,复选框类型在服务端所对应的map类型会重新加载。
*/
public String getSelectedItems() {

// Get selected items.
selectList = new ArrayList<User>();
setCount(selectedDataList.size());
for (User dataItem : selectedDataList) {
System.out.println(manySelect.getLisMap().get(dataItem.getId()));

}
return "selectMany.xhtml";
}

public void setAll(){
Map<Long, Boolean> map = manySelect.getLisMap();
for(Map.Entry<Long, Boolean> entry:map.entrySet()){
entry.setValue(error);
}
}

@Transactional
public String removeSelect() {
Map<Long, Boolean> map = manySelect.getLisMap();
for(Map.Entry<Long, Boolean> entry:map.entrySet()){
if(entry.getValue()){

Long sid = entry.getKey();
System.out.println("id====="+sid);
User user = entityManager.find(User.class, sid);
entityManager.remove(user);
}
}
return "selectMany.xhtml";
}

// Getters -----------------------------------------------------------------------------------


public List<User> getSelectedDataList() {
return selectedDataList;
}

public void setCount(long count) {
this.count = count;
}

public long getCount() {
return count;
}

public List<User> getSelectList() {
return selectList;
}

public void setSelectList(List<User> selectList) {
this.selectList = selectList;
}

public void setSelectedDataList(List<User> selectedDataList) {
this.selectedDataList = selectedDataList;
}

public boolean isError() {
return error;
}

public void setError(boolean error) {
this.error = error;
}


}
selectMany是由自己定义封装好的一个hashMap类,里面一系列操作可以更具自己多多选框的要求来设置,如不用selectMany也可以在此类中重新构造一个map函数
打开链接下载源码: https://pan.quark.cn/s/331a85e1b463 在数字化时代背景下,软件授权与保护显得极为关键,微狗(MicroDog)作为一款硬件加密狗,其主要功能是保障软件的合法使用,避免盗版和未经授权的访问。为了达成这一目的,微狗驱动发挥着不可或缺的作用。驱动程序充当硬件与操作系统之间的沟通纽带,确保两者能够和谐协作。现阶段,64位微狗驱动(UMI64位)已经兼容Windows 11、Windows 10以及Windows 7操作系统,为不同的系统环境提供坚实可靠的支持。 随着Windows操作系统的持续升级,对驱动程序的兼容性需求也在逐步提高。微狗驱动UMI64位版本正是为了应对兼容性问题而研发的。它不仅适配最新版的Windows 11,同时也与过去几年中普遍应用的Windows 10和Windows 7保持兼容。如此全面的系统支持,使得微狗加密狗能够在多种环境中稳定运作,确保软件授权管理不受操作系统版本的限制。 在这个驱动中,特别强调了支持UMI V4.1版本。UMI可能代表Unique Machine Identifier,即用于标识特定硬件设备的唯一序列号。提及UMI V4.1表明该驱动能够精准识别并支援微狗加密狗的此特定型号。同时,这也暗示驱动可能与其他版本的微狗硬件兼容,这意味着用户可以在不同版本的微狗加密狗之间切换而不必频繁更换驱动程序。 UMI64位标签凸显了驱动程序的核心特征,即它专为64位系统进行优化。相较于32位系统,64位系统在处理海量数据、运行大型应用时展现出显著优势,例如能够支持更大的内存地址空间。随着软件复杂性的提升,对硬件资源的需求持续增长,因此64位系统能够提供更优越的性能和稳定性。UMI系列硬件与...
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值