无法使用支持 bean 进行过滤

Can't filter using backing bean

我正在尝试使用支持 bean 函数过滤列。

<p:dataTable id="cars" 
             var="car" 
             value="#{manageAllCoursesBean.courses}"
             filteredValue="#{manageAllCoursesBean.filteredCourse1}"> 

    <f:facet name="header">
        <p:outputPanel>
            <p:inputText id="globalFilter" 
                         onkeyup="PF('carsTable1').filter()" 
                         style="width:250px" 
                         placeholder="Entrer un mot clé"/>
        </p:outputPanel>
    </f:facet>

    <p:column headerText="Name"
              filterBy="#{car.name}"
              sortBy="#{car.name}"
              style="color: #400040; font-size: 10px; width: 150px; text-align:center">
        <h:outputText value="#{car.name}" />
    </p:column>

    <p:column headerText="Teacher"
              filteredBy="#{manageAllCoursesBean.findTeacherByIdCourse(car.id)}"
              sortBy="#{manageAllCoursesBean.findTeacherByIdCourse(car.id)}"
              style="color: #400040; font-size: 10px; width: 175px; text-align:center">
        <h:outputText value="#{manageAllCoursesBean.findTeacherByIdCourse(car.id)}" />
    </p:column>

</p:dataTable>

支持 bean 方法是:

public String findTeacherByIdCourse(String courseId) throws IOException
{
    return serviceManager.findTeacherByCourseId(courseId);
}

名称为 的过滤器也正常工作。 但是,Teacher.

的情况并非如此

请问您对解决这个问题有什么想法吗?。 非常感谢。

Primefaces showcase 所述,p:column 下的 filterBy 无法使用托管 bean 方法。

我提出了这样的解决方案: 您可以将实体 Course 转换为 courseModel,然后添加 teachers 作为字符串列表。

然后在您的托管 bean 中将是:

List<CourrierModel> lacmss = new ArrayList<CourrierModel>();
DataModel allDatasAssociatedCE = new ListDataModel();

//...

allDatasAssociatedCE.setWrappedData(lacmes);
for(Course c: courses)
{
   CourseModel cme = new CourseModel();
   cme.setCourse(c);
   cme.setTeachers(findTeacherByIdCourse(c));
   lacmss.add(cme);
}

HTH.