如何在更新表中保持primefaces rowexpansion开放?

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

嗨我有一个带有p:rowToggler的数据表,所以当从行expasion启动弹出窗口时,关闭弹出窗口后我需要更新行中的一些标签。更新有效!但行扩大了,崩溃了。如何在关闭弹出窗口并更新内容后继续打开行扩展。谢谢。

PopUp片段

 <p:ajax event="close"  update=":id1:id2"  oncomplete="someJavascript()" />

数据表片段

<h:form prependId="false" id="id1"> 
            <h:panelGroup id="id2" >
                  <p:dataTable tableStyleClass="win" var="element"                                id="table1" value="#{myBean.list}"
                            selectionMode="single"  rowExpandMode="single" rowIndexVar="cont" widgetVar="table1"
                           selection="#{myBean.selectedRecord}" rowKey="#{element.id}"   >
<p:ajax event="rowToggle"    listener="#{myBean.methodBean(element)}" /> 
                     <p:column styleClass="rowTogglerStyle" 
<p:rowToggler collapseLabel="#{bundle.show}" 
 expandLabel="#{bundle.show}">
</p:rowToggler>                    
</p:column> 

</p:datatable>  </h:panelGroup>  </h:form>
jsf primefaces
2个回答
2
投票

如果您保存展开的行元素ID,则可以这样做:

<p:dataTable expandedRow="#{element.id == myBean.expandedRowElementId}">
    <p:ajax event="rowToggle" listener="#{bean.setExpandedRowElementId(element.id)}"/>

为了防止再次打开它,你需要稍微修改一下setter:

public void setExpandedRowElementId(String expandedRowElementId){
  if(this.expandedRowElementId != null && expandedRowElementId.equals(this.expandedRowElementId) 
  // if the id is equal the expansion is closed, so the expanded element must be set to null
     this.expandedRowElementId = null;
  else
     this.expandedRowElementId = expandedRowElementId;
}

0
投票

嗨,问题是关闭弹出窗口后选定的行扩展还有类ui-state-highlight,所以我发现在p:ajax中的onclomplete atributte中通过javascript重新打开关闭的rowexpansion:

jQuery('tr.ui-state-highlight')。find('td.rowTogglerStyle> div.ui-row-toggler')。trigger('click');

我希望它对其他人有用。

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