p:datatable と動的な列を含むページがあります。コマンド ボタン クリックの値として f:attribute を使用して、ヘッダーにコマンド ボタンを追加しようとしています。問題は、ヘッダー ボタンを押してもサーバーにまったくアクセスできないことです。ここにコードスニペットがあります
<p:dataTable >
<p:columns value="#{controller.columnsTitles}" var="column" columnIndexVar="colIndex">
<f:facet name="header">
<p:panel >
<table>
<tr>
<th>
<p:panel>
#{column.label}
</p:panel>
</th>
</tr>
<tr>
<th>
<h:panelGroup >
<p:commandButton value="Add" actionListener="#{controller.doStaff}">
<f:setPropertyActionListener value="#{column.value}" target=#{controller.selectedToEdit}" />
</p:commandButton>
</h:panelGroup>
</th>
</tr>
</table>
</p:panel>
</f:facet>
<p:column>
......
</p:column>
</p:columns>
</p:dataTable>
[編集] この問題の解決策を見つけました。commandbutton に onClick イベントを追加しました。このイベントは、パラメーター selectedToEdit を javascript 関数に渡します。この関数は、パラメーターをサーバーに渡す ap:remoteCommand を呼び出します。また、commandButton の actionListener を action に変更したところ、動作するようになりました。
コードは次のようになります。
<script>
function jsFunc(param)
{
command([{name:'selectedToEdit',value:selectedToEdit}]);
}
</script>
.....
<p:remoteCommand name="command" actionListener="#{controller.selectedToEdit}" />
<p:commandButton value="Add" action="#{controller.doStaff}" onclick="jsFunc('#{column.value}')" />