У меня есть таблица данных. В каждой строке таблицы есть commandButton
с именем 'Remove' , который должен удалить эту строку из модели и вида и выполнить обновление на месте. В качестве нижнего колонтитула у меня есть еще один commandButton
с именем 'Удалить все строки' .
Последняя кнопка работает. Я нажимаю на нее, каждая строка удаляется из модели (т. Е. ArrayList
, содержащий элементы, становится пустым), а dataTable
и footer facet
повторно отображаются (или обновляются) в представлении.
С другой стороны, когда я нажимаю кнопку в одной из строк, чтобы удалить ее, она частично работает. Соответствующий элемент удаляется из модели, но представление не обновляется. Эта строка все еще там в dataTable
, а footer facet
не изменилась.
У меня есть следующий фрагмент кода в моем users.xhtml
.
<f:metadata>
<f:viewParam name="id" value="#{users.id}" />
<f:event type="preRenderView" listener="#{users.init}" />
</f:metadata>
...
<h:form id="usersForm">
<p:outputPanel>
<p:dataTable id="userTable" value="#{users.user.friendList}" var="friend">
<p:column>
<h:outputText value="#{friend.name}" />
</p:column>
<p:column>
<p:commandButton action="#{users.user.removeFriend(friend)}"
ajax="true"
update="userTable somethingElse" process="@this"
onerror="errorDialog.show();"
icon="ui-icon-delete"
title="delete user">
</p:commandButton>
</p:column>
<f:facet id="somethingElse" name="footer">
aye: ${users.user.xxx}
</f:facet>
</p:dataTable>
</p:outputPanel>
<p:commandButton action="#{users.user.removeAllFriends()}" ajax="true"
update="userTable somethingElse"
process="@this"
icon="ui-icon-close"
value="delete all friends?">
</p:commandButton>
</h:form>
Так, как вы думаете, в чем здесь проблема?
Я использую JSF 2.0 и Primefaces 3.0