commandButton update属性不起作用

时间:2016-07-04 07:59:55

标签: ajax primefaces commandbutton

我有一个commandButton,它打开一个包含表格的对话框。

单击该按钮时,弹出对话框,但不包含任何内容。

这是我的代码:

<h:panelGroup id="correctionsEntries" layout="block">

    <p:dataTable styleClass="dataTable" id="entriesTable" var="entry" value="#{bean.tableModel.items}">

        <p:columnGroup type="header">
            <p:row>
                <ui:repeat var="column" value="#{bean.tableModel.columns}" varStatus="colStatus">
                    <p:column  headerText="#{column.header}">
                    </p:column>
                </ui:repeat>
            </p:row>
        </p:columnGroup>

        <c:forEach var="column" items="#{bean.tableModel.columns}">

            <c:choose>  
                <c:when test="${column.header eq 'Upload'}">
                    <p:column>
                        <p:commandButton value="Upload" immediate="true" actionListener="#{bean.setSelectedRow(entry)}" oncomplete="PF('upload').show();" />

                        <p:dialog header="Upload" widgetVar="upload" height="10%" width="80%">
                            <p:messages binding="#{bean.component}" /> 
                            <p:fileUpload fileUploadListener="#{bean.uploadCSV}" />
                        </p:dialog>
                    </p:column>
                </c:when>

                <c:when test="${column.header eq 'Export'}">
                    <p:column>
                        <p:commandButton value="Download" immediate="true" ajax="false" actionListener="#{bean.setSelectedRow(entry)}">
                            <p:fileDownload value="#{bean.downloadCSV()}" />
                        </p:commandButton>
                    </p:column>
                </c:when>

                <c:when test="${column.header eq 'Display'}">
                    <p:column>
                        <p:commandButton id="displayButton" value="Display"
                            immediate="true"
                            action="#{tableBean.execute(entry)}"
                            update="displayTable"
                            oncomplete="PF('dialog').show();" />

                        <p:dialog id="dialog" header="Current data" widgetVar="dialog" height="80%" width="80%">

                            <p:dataTable styleClass="dataTable"
                                id="displayTable" var="tableDataVar"
                                value="#{tableBean.tableModel.data}"
                                tableStyle="width:auto;" resizableColumns="true">

                                <p:columns var="tableHeader" value="#{tableBean.tableModel.headers}">
                                    <f:facet name="header">
                                        <h:outputText value="#{tableHeader}" />
                                    </f:facet>
                                    <h:outputText value="#{tableDataVar[tableHeader]}" />

                                </p:columns>

                            </p:dataTable>

                        </p:dialog>
                    </p:column>
                </c:when>

                <c:when test="${column.header eq 'Test'}">
                    <p:column>
                        <p:commandButton value="Test" immediate="true" ajax="false" actionListener="#{bean.setSelectedRow(entry)}">
                            <p:fileDownload value="#{bean.testFilesDownload()}" />
                        </p:commandButton>
                    </p:column>
                </c:when>

                <c:otherwise>
                    <p:column>
                        <h:outputText value="#{bean.tableModel.get(entry, column)}" />
                    </p:column>
                </c:otherwise>
            </c:choose>
        </c:forEach>

    </p:dataTable>  

</h:panelGroup>

只有在刷新页面后才会显示该表。

1 个答案:

答案 0 :(得分:0)

问题是,为父表中的每个列创建了一个包含该表的对话框。

因此,有与列相同的对话框。

对此的修复是以单独的形式添加对话框,并通过指定其路径在commandButton中引用它。