primefaces数据表不能使用列切换器正确刷新

时间:2018-02-02 15:59:32

标签: jsf primefaces pf-datatable

用户刚注意到我的数据表中存在一个大错误。当您使用数据表和列切换器时,取消选择列只会移动一些行,但是当某些单元格为空时它会出错。

所以我尝试用

刷新我的数据表
`<p:columnToggler datasource="datalist" trigger="toggler">
  <p:ajax event="toggle" update="datalist"/>
</p:columnToggler>`

但它出错:

`<p:columns value="#{consultationView.columns}" var="column" columnIndexVar="colIndex" 
visible="#{column.property.matches('Z06|Z07|Z09')}" >`

因为如果我取消选择一个可见的列,它会再次显示...

这是完整的数据表:     `

 <f:facet name="header">
 <p:commandButton process="listFDP" icon="ui-icon-file-pdf" value="Editer les fiches de paie" action="#{consultationView.printPaieAgent()}" escape="false" ajax="false" onclick="this.form.target='_blank'" />

 <p:commandButton id="toggler" type="button" value="Colonnes"
                            style="float:right" icon="ui-icon-calculator" />
 <p:columnToggler datasource="datalist" trigger="toggler">
  <p:ajax event="toggle" update="datalist"/>
 </p:columnToggler>

 </f:facet>

 <p:column selectionMode="multiple" style="width:16px;text-align:center" exportable="false" toggleable="false" />
 <p:column style="width:60px;text-align:left"
                        sortBy="#{row.gestion.datePaiement}" headerText="Pér. Paie" groupRow="true" sortOrder="ASCENDING" >
 <h:outputText value="#{row.gestion.datePaiement}">
 <f:converter binding="#{dateConverterMoisAnnee}" />
 </h:outputText>
 </p:column>
 <p:column style="width:60px;text-align:left"
                        sortBy="#{row.gestion.dateOrigine}" headerText="Pér. Origine">
                        <h:outputText value="#{row.gestion.dateOrigine}">
 <f:converter binding="#{dateConverterMoisAnnee}" />
 </h:outputText>
 </p:column>

 <p:column headerText="N° cont." style="width:25px;text-align:center;white-space:pre-line;">
 <h:outputText value="#{row.gestion.matricule.substring(10)}" />
 </p:column>

 <p:column headerText="Statut" style="width:150px;text-align:left;white-space:pre-line;" sortBy="#{row.statut}">
 <h:outputText value="#{row.statut}" />
 </p:column>

 <p:columns value="#{consultationView.columns}" var="column" columnIndexVar="colIndex" 
                        visible="#{column.property.matches('Z06|Z07|Z09')}" >
 <f:facet name="header">
  <h:outputText value="#{column.header}" />
 </f:facet>
 <h:outputText value="#{row.getRubValue(column.property)}" />
 </p:columns>
</p:dataTable>`

很抱歉很长的帖子xs

0 个答案:

没有答案