p:dataTable具有多重选择功能的rowSelect事件不会触发

问题描述 投票:0回答:1

我有p:datatable as

 <p:dataTable id="tasktable" rows="5"  paginator="true" paginatorPosition="bottom" rowsPerPageTemplate="5,10,25" editable="true" editMode="row" reflow="true"
         value="#{taskBean.taskList}" selectionMode="multiple" binding="#{table}" rowKey="#{currentrow[0]}" selection="#{taskBean.selectedTaskList}" var="currentrow"}">

<p:column headerText="Select" id="checkboxSelect" selectionMode="multiple" styleClass='text-md-center com-wdth-5 white'>

</p:column>

<f:facet name="header">
    <div>
        <p:commandButton id="toggler" type="button" value="Select Columns" icon="ui-icon-calculator" styleClass="btn ad-btn-danger padd mr-b0"/>
        <p:columnToggler datasource="tasktable" trigger="toggler" />
    </div>
</f:facet>
<p:column id="sno" styleClass="com-wdth-5">
    <f:facet name="header"> #{msg['CHSN']} </f:facet> 
    <h:outputLabel value="#{table.rowIndex + 1}"/>  
</p:column>
.
.
.
 <p:ajax event="rowSelect" listener="#{taskBean.onRowSelect}" update="@form"/>
</p:dataTable>

具有event =“ rowSelect”和selectionMode为多个,具有作为后备bean代码的

public void onRowSelect(SelectEvent event) {

    System.out.println("selectedTaskList = "+selectedTaskList.size());
}

但是此rowSelect是从不触发,并且复选框不是selectable,但是如果我从p:dataTable remove selectionMode =“ multiple”,则启用选择,但不会触发事件。并且selectedTaskList只是一个全局定义为的arrayList:私有列表selectedTaskList = new ArrayList <>();

jsf primefaces
1个回答
0
投票

我错过了其他p:dataTable事件。我使用这些事件进行了纠正]

<p:ajax event="rowSelect" listener="#{taskBean.onRowSelect}" update="@this taskToolbar" />
<p:ajax event="rowUnselect" listener="#{taskBean.onRowUnselect}" update="@this taskToolbar" />
<p:ajax event="rowSelectCheckbox" listener="#{taskBean.onRowSelect}" update="@this taskToolbar" />
<p:ajax event="rowUnselectCheckbox" listener="#{taskBean.onRowUnselect}" update="@this taskToolbar" />
<p:ajax event="toggleSelect" process="@this" update="@this taskToolbar" listener="#{taskBean.onAllRowSelect}"/>

和我的后备豆代码

public void onRowSelect(SelectEvent event) {
        displayTag();
    }

    public void onRowUnselect(UnselectEvent event) {
        displayTag();
    }

    public void onAllRowSelect(AjaxBehaviorEvent event) {
        displayTag();
    }

    public void displayTag() {
        if (selectedTaskList != null && !selectedTaskList.isEmpty()) {
            hideTag = true;
        } else {
            hideTag = false;
        }
    }

Where selectedTaskList是要在其中保存表的选定行的列表

© www.soinside.com 2019 - 2024. All rights reserved.