<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"
生成されたHTMLコードを調べて、panelGrid用に生成されている実際のIDを確認し、そのIDを更新してください。たまたま動的である場合は、いつでもJQuery CSSセレクターを使用できます(私はかなり頻繁にそれを行っていることに気付きます)。あなたの場合、次のようにすることができます:
update="@([id$=output])"
この式は、idが出力で終わるすべてのコンポーネントを表します。詳細については、JQueryのドキュメントをご覧ください。
以下のように:#{p:component(componentId)}
を使用することもできます
<p:ajax listener="#{providerSelectBean.onRowSelect}"
update=":#{p:component('output')}" event="rowSelect"/>
BalusCの に対する回答を引用して、レンダー/更新属性のテンプレートの親ネーミングコンテナのIDを取得します :
p:componentは、指定されたIDを持つコンポーネントのビュールート全体をスキャンし、そのクライアントIDを返すヘルパー関数です。