У меня есть страница с p: datatable и динамическими столбцами. Я пытаюсь добавить командную кнопку в заголовки с атрибутом f: в качестве значения для нажатия командной кнопки. проблема в том, что я вообще не попадаю на сервер при нажатии кнопки заголовка. вот фрагмент кода
<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>
[Изменить] Я нашел решение этой проблемы. К командной кнопке я добавил событие onClick, которое передает параметр selectedToEdit функции javascript, которая, в свою очередь, вызывает p:remoteCommand, которая передает параметр на сервер. Я также изменил actionListener commandButton на 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}')" />
ajax="true"
по умолчанию. если вы хотите нормальное поведение кнопки, вам нужно явно установить значение false - person Przemek   schedule 03.07.2013