PrimeFaces,数据过滤问题+ Ajax表更新

时间:2013-07-30 10:28:02

标签: java jsf primefaces datatable filtering

我正在使用PF 3.5社区版,我遇到以下问题。

我构建了一个Datatable,它使用Filters作为一列和可选行以及上下文菜单。

当我使用AJAX插入新条目(通过对话框)并更新数据表时,这似乎会产生某种冲突。第一次插入总是有效,后续似乎永远不会调用动作监听器。我使用courseTable.filter();到处都是,但这个问题仍然存在。我尝试在具有过滤器和不可选行的数据表上以及没有过滤器和可选行的数据表上执行相同的操作。这两种情况都可行,但这种组合有问题。

<h:form id="mainForm">
        <p:focus />

        <!-- Main Data-table  -->
        <h:panelGrid style="width:700px;">

            <p:dataTable var="c" id="courseTable" widgetVar="courseTable"
                value="#{course.courseList}" rowKey="#{c.courseId}"
                selectionMode="single"
                filteredValue="#{course.filteredCourseList}">

                <p:ajax event="filter" global="false" />

                <f:facet name="header">
                    <p:commandButton value="Add Course" process="@this"
                        update="@this :courseForm" oncomplete="dlgInsertCourse.show()"/>
                </f:facet>

                <p:column id="courseCode" filterBy="#{c.courseCode}"
                    sortBy="#{c.courseCode}" filterMatchMode="contains"
                    headerText="Course Code">
                    <h:outputText value="#{c.courseCode}" />
                </p:column>

                <p:column id="courseName" filterBy="#{c.courseName}"
                    sortBy="#{c.courseName}"filterMatchMode="contains"
                    headerText="Course Name">
                    <h:outputText value="#{c.courseName}" />
                </p:column>

                <p:column id="courseType" filterBy="#{c.courseType}"
                    sortBy="#{c.courseType}"
                    filterOptions="#{course.courseTypeOptions}" 
                    headerText="Course Type" filterMatchMode="exact">
                    <h:outputText value="#{c.courseType}" />
                </p:column> 
            </p:dataTable>

        </h:panelGrid>

        <!-- Context Menu -->
        <p:contextMenu for="courseTable">

            <p:menuitem value="Edit" icon="ui-icon-pencil"
                update=":courseForm"
                oncomplete="dlgInsertCourse.show()"/>

                <p:menuitem value="Delete" icon="ui-icon-trash" update="@form"
                oncomplete="courseTable.filter();" />
        </p:contextMenu>
    </h:form>

    <!-- Insert Course Dialog  -->
    <p:dialog header="Create" widgetVar="dlgInsertCourse"
        draggable="true" resizable="false">
        <h:form id="courseForm">
            <p:panelGrid columns="1">

                <p:row>
                    <p:panelGrid columns="2">

                        <p:outputLabel value="Course Code: *"/>
                        <p:inputText label="Course Code"
                            value="#{course.course.courseCode}" />

                        <p:outputLabel value="Course Name: *"  />
                        <p:inputText label="CourseName"
                            value="#{course.course.courseName}" />

                        <p:outputLabel value="Course Type: *"  />
                        <p:selectOneRadio label="Course Type"
                            value="#{course.course.courseType}">
                            <f:selectItem itemLabel="Core" itemValue="Core" />
                            <f:selectItem itemLabel="Elective" itemValue="Elective" />
                        </p:selectOneRadio>

                    </p:panelGrid>
                </p:row>

            </p:panelGrid>

            <h:panelGroup style="display:block; text-align:center">
                <p:commandButton value="Submit" update="@form :mainForm :messages"
                    process="@form" 
                    oncomplete="if (!args.validationFailed) dlgInsertCourse.hide();"
                    actionListener="#{course.saveCourse()}"
                    />
            </h:panelGroup>
        </h:form>
    </p:dialog>

更详细:

  1. 在我添加数据表之后,现在我可以正常添加课程,如果我没有应用过滤器
  2. 我没有使用过courseTable.filter();在提交对话框中。如果我使用它,即使我没有应用过滤器也无法添加课程
  3. 删除似乎与我尝试的任何设置完美配合(使用应用过滤器和未应用)。

1 个答案:

答案 0 :(得分:0)

找到解决方案。

似乎在支持bean中使用不同的对象来存储数据表选择,而“插入课程对话框”的另一个用于解决问题。

在我的情况下,我在两者中都使用了#{course.course}。现在我添加了一个#{course.selectedCourse}来处理数据表。

当然应该相应更新支持bean。