[英]Primefaces Ajax action not triggering update
我在下面的页面上,一切正常...
除了单击删除按钮并在“确认”对话框中单击“是”之后,我的页面没有改变...它应该显示没有该用户的相同表格。
我尝试了很多事情,但是我使用的是Primefaces 3.0.M3我的表单表是服务器创建的,因此应该可以使用ajax。
任何人都知道哪里错了吗?
谢谢 !
<h:form id="main" prependId="false">
<p:dataTable var="user" value="#{userController.allUsers}" id="userTable">
<p:ajax event="rowEdit" update="@this" listener="#{userController.onEditRow}" />
<f:facet name="header">
#{bundle.ListOfUsers}
</f:facet>
<p:column headerText="#{bundle.USERNAME}" style="width:110px">
<p:cellEditor>
<f:facet name="output">
<h:outputText value="#{user.name}" />
</f:facet>
<f:facet name="input">
<p:inputText value="#{user.name}" style="width:110%"/>
</f:facet>
</p:cellEditor>
</p:column>
<p:column headerText="#{bundle.Login}" style="width:100px">
<p:cellEditor>
<f:facet name="output">
<h:outputText value="#{user.login}" />
</f:facet>
<f:facet name="input">
<h:outputText value="#{user.login}" />
</f:facet>
</p:cellEditor>
</p:column>
<p:column headerText="#{bundle.Roles}" style="width:180px;">
<p:cellEditor>
<f:facet name="output">
<h:outputText value="#{user.rolesCollection}"/>
</f:facet>
<f:facet name="input">
<p:selectManyMenu value="#{user.rolesCollection}"
converter="rolesConverter"
style=" width:100%;">
<f:selectItems value="#{roleController.listOfRoles}"
var="roles"
itemLabel="#{roles.rolename}"
itemValue="#{roles}"
/>
</p:selectManyMenu>
</f:facet>
</p:cellEditor>
</p:column>
<p:column headerText="#{bundle.edit}" style="width:10px; overflow:visible;">
<p:rowEditor/>
</p:column>
<p:column headerText="#{bundle.delete}" style="width:10px; overflow:visible;">
<p:commandButton update=":main" oncomplete="confirmation.show()" image="ui-icon ui-icon-close" title="Delete" >
<f:param value="#{user.id}" name="userAction" />
</p:commandButton>
</p:column>
</p:dataTable>
<p:confirmDialog message="Are you sure? user:#{param['userAction']} " width="500"
header="Confirm" severity="alert" widgetVar="confirmation" >
<p:commandButton value="Yes sure" update="userTable" actionListener="#{userController.deleteAction( param['userAction'])}" oncomplete="confirmation.hide()" >
<f:param name="userAction" value="#{param['userAction']}" />
</p:commandButton>
<p:commandButton value="Not yet" onclick="confirmation.hide()" type="button" />
</p:confirmDialog>
</h:form>
这是控制器方法
public void deleteAction(String id){
userFacade.remove(userFacade.find(Integer.parseInt(id)));
}
该方法正在被调用,并且正在删除用户。
删除用户后,您需要在bean的action方法中重新加载allUsers
列表。
public void deleteAction(String userId) {
userService.delete(Long.valueOf(userId));
allUsers = userService.list();
}
否则,JSF只会检索原始列表。 您显然是在视图作用域的bean的(post)构造函数中预先填充了列表,这就是F5起作用的原因。
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.