PrimeFaces TypeError: PF(...) is undefined



我在自己的DataTable上遵循了PrimeFaces的DataTable Filter展示。每次"onkeyup"事件发生时,我都会得到一个

TypeError: PF(…)是Firebug中未定义的错误,并且是"Uncaught "TypeError:无法读取未定义属性"filter"

在Chrome控制台。过滤不起作用

这是我的XHTML页面:

<?xml version="1.0" encoding="UTF-8"?>
<html xmlns="http://www.w3.org/1999/xhtml"
      xmlns:h="http://java.sun.com/jsf/html"
      xmlns:f="http://java.sun.com/jsf/core"
      xmlns:p="http://primefaces.org/ui">
    <h:head>
        <h:title>List of User</h:title>
    </h:head>
    <h:body>
        <h:form id="UserForm" name="UserRecords">
            <p:dataTable id="users" widgetVar="usersTable" var="user" value="#{userBean.users}" scrollable="false" frozenColumns="0" sortMode="multiple" stickyHeader="true" filteredValue="#{userBean.filteredUsers}">
                <f:facet name="header">User<p:inputText id="globalFilter" onkeyup="PF('usersTable').filter()" style="float:right" placeholder="Filter"/>
                    <p:commandButton id="toggler" type="button" style="float:right" value="Columns" icon="ui-icon-calculator"/>
                    <p:columnToggler datasource="users" trigger="toggler"/>
                    <p:commandButton id="optionsButton" value="Options" type="button" style="float:right"/>
                    <p:menu overlay="true" trigger="optionsButton" my="left top" at="left bottom">
                        <p:submenu label="Export">
                            <p:menuitem value="XLS">
                                <p:dataExporter type="xls" target="users" fileName="users"/>
                            </p:menuitem>
                            <p:menuitem value="PDF">
                                <p:dataExporter type="pdf" target="users" fileName="users"/>
                            </p:menuitem>
                            <p:menuitem value="CSV">
                                <p:dataExporter type="csv" target="users" fileName="users"/>
                            </p:menuitem>
                            <p:menuitem value="XML">
                                <p:dataExporter type="xml" target="users" fileName="users"/>
                            </p:menuitem>
                        </p:submenu>
                    </p:menu>
                </f:facet>
                <p:column disabledSection="false" colspan="1" exportable="true" filterBy="#{user.firstName}" filterMatchMode="startsWith" filterStyle="display:none; visibility:hidden;" filterable="true" headerText="FirstName" priority="0" rendered="true" resizable="true" rowspan="1" selectRow="true" sortable="true" toggleable="true" visible="true">
                    <h:outputText value="#{user.firstName}"/>
                </p:column>
                <p:column disabledSection="false" colspan="1" exportable="true" filterBy="#{user.lastName}" filterMatchMode="startsWith" filterStyle="display:none; visibility:hidden;" filterable="true" headerText="LastName" priority="0" rendered="true" resizable="true" rowspan="1" selectRow="true" sortable="true" toggleable="true" visible="true">
                    <h:outputText value="#{user.lastName}"/>
                </p:column>
                <p:column disabledSection="false" colspan="1" exportable="true" filterBy="#{user.username}" filterMatchMode="startsWith" filterStyle="display:none; visibility:hidden;" filterable="true" headerText="Username" priority="0" rendered="true" resizable="true" rowspan="1" selectRow="true" sortable="true" toggleable="true" visible="true">
                    <h:outputText value="#{user.username}"/>
                </p:column>
                <p:column disabledSection="false" colspan="1" exportable="true" filterBy="#{user.password}" filterMatchMode="startsWith" filterStyle="display:none; visibility:hidden;" filterable="true" headerText="Password" priority="0" rendered="true" resizable="true" rowspan="1" selectRow="true" sortable="true" toggleable="true" visible="true">
                    <h:outputText value="#{user.password}"/>
                </p:column>
                <p:column disabledSection="false" colspan="1" exportable="true" filterBy="#{user.id}" filterMatchMode="startsWith" filterStyle="display:none; visibility:hidden;" filterable="true" headerText="Id" priority="0" rendered="true" resizable="true" rowspan="1" selectRow="true" sortable="true" toggleable="true" visible="true">
                    <h:outputText value="#{user.id}"/>
                </p:column>
                <p:column disabledSection="false" colspan="1" exportable="true" filterBy="#{user.createdOn}" filterMatchMode="startsWith" filterStyle="display:none; visibility:hidden;" filterable="true" headerText="CreatedOn" priority="0" rendered="true" resizable="true" rowspan="1" selectRow="true" sortable="true" toggleable="true" visible="true">
                    <h:outputText value="#{user.createdOn}"/>
                </p:column>
                <p:column disabledSection="false" colspan="1" exportable="true" filterBy="#{user.lastModified}" filterMatchMode="startsWith" filterStyle="display:none; visibility:hidden;" filterable="true" headerText="LastModified" priority="0" rendered="true" resizable="true" rowspan="1" selectRow="true" sortable="true" toggleable="true" visible="true">
                    <h:outputText value="#{user.lastModified}"/>
                </p:column>
            </p:dataTable>
        </h:form>
    </h:body>
</html>

我使用的是PrimeFaces 5.2与Mojarra 2.2.8和JSF 2.2.10。

在我的例子中,我发现我的TypeError: PF(...) is undefined错误(没有额外的属性错误)是由Primefaces无法找到小部件widgetVar="usersTable"(例如,由于拼写错误

)引起的

在这种情况下,Firebug中错误上方的控制台输出给您的解释是Widget for var 'editExecContactDialogg' not available!

运行时类路径包含重复的不同版本库时,就会发生这种情况。冲突将在类加载和资源解析期间发生。

确保您只使用一个版本的库。这不仅适用于PrimeFaces,也适用于Mojarra。同时使用2.2.8和2.2.10肯定是不对的。

就像@hendinas的回答一样,这不是解决特定问题的方法,但可能对未来有相同错误但原因不同的谷歌用户有帮助。

这是@hendinas回答的另一个例子,但是您所指的东西没有找到,因为它没有相同的rendered条件。下面是一个例子。

<ui:repeat id="extSyses" var="extSys" value="${cc.attrs.externalSystems}"
        varStatus="extSysLoop">
    <h:commandButton
        id="YesButton" value="Yes" type="button"
        rendered='#{(rptBean.canEditReport or rptBean.canAnnotateReport) and not extSys.closed)}'
        onclick="PF('#{cc.attrs.prefix}yesDlg#{extSysLoop.index}').show()" />
    <p:dialog id="extDocDlg" header='Enter document reference number'
        rendered='#{rptBean.canEditReport and not extSys.closed)}'
        widgetVar="#{cc.attrs.prefix}yesDlg#{extSysLoop.index}"
        width="650" minWidth="650" modal="true">
       ... Dialog Content ...
    </p:dialog>
</ui:repeat>

在这种情况下,widgetVar匹配onclick的值,所以这很好。然而,rendered条款有所不同。如果canEditReport是真的,那么一切都很好。然而,如果canAnnotateReport为真,那么按钮将显示,但它将没有对话框显示!点击按钮,显示TypeError: PF(…) is undefined提示信息。

在本例中,解决方案是使按钮和它所引用的对话框的rendered子句相同。

相关内容

  • 没有找到相关文章

最新更新