Primefaces - 无法在数据表外找到标识符的组件

时间:2012-11-21 18:22:13

标签: jsf primefaces

 <ui:define name="content">
    <f:view>                        
    <h:form id="myForm" styleClass="form" >

        <p:dataTable var="provider" id="ss"  value="#{providerSelectBean.providerList}" rowKey="#{provider.license}"  

            selection="#{providerSelectBean.selectedProvider}" selectionMode="single"> 

            <p:ajax listener="#{providerSelectBean.onRowSelect}"    
                            update=":myForm:output"event="rowSelect"/>  

            <p:column sortBy="#{provider.license}" width="110" >
                <f:facet name="header">
                    <h:outputText value="License#" />
                </f:facet>
                <h:outputText value="#{provider.license}" />
            </p:column>

            <p:column sortBy="#{provider.prgName}" width="110" >
                <f:facet name="header">
                    <h:outputText value="Program Name" />
                </f:facet>
                <h:outputText value="#{provider.prgName}" />
            </p:column>

        </p:dataTable><br/>

        <p:panelGrid id="output" >
            <h:outputText value="License" />
            <h:outputText value="#{provider.license}" /> 
        </p:panelGrid>

    </h:form>           
    </f:view>

</ui:define>    

这是我第一次使用JSF2.0和primefaces 3.4.1,而<p:ajax update给出错误

javax.faces.FacesException: Cannot find component with identifier  
":myForm:output"  referenced from "myForm:ss"

2 个答案:

答案 0 :(得分:27)

尝试检查生成的HTML代码,并查看为panelGrid生成的实际ID并更新该ID。如果它恰好是动态的,你总是可以使用JQuery CSS选择器(我发现自己经常这样做)。在你的情况下,你可以这样:

update="@([id$=output])"

此表达式表示id以输出结尾的每个组件。有关更多信息,请查看JQuery文档。

答案 1 :(得分:25)

您也可以在

中使用:#{p:component(componentId)}
<p:ajax listener="#{providerSelectBean.onRowSelect}"  
update=":#{p:component('output')}" event="rowSelect"/>

引用BalusC对Get id of parent naming container in template for in render / update attribute的回答:

  

p:component是一个帮助函数,它扫描整个视图根,查找具有给定ID的组件,然后返回其客户端ID。