Primefaces Ajax操作不会触发更新

时间:2011-10-14 20:48:56

标签: java ajax jsf jsf-2 primefaces

我有下面的页面,一切正常......

在我点击删除按钮并在确认对话框中点击“是的确定”后,我的页面不会改变...它应该显示没有该用户的相同表格。

我尝试了很多东西,但我使用的是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)));

} 

正在调用此方法,它正在删除用户。

1 个答案:

答案 0 :(得分:1)

删除用户后,您需要在bean的操作方法中重新加载allUsers列表。

public void deleteAction(String userId) {
    userService.delete(Long.valueOf(userId));
    allUsers = userService.list();
}

否则JSF将只检索原始列表。您显然是在视图范围bean的(post)构造函数中预填充列表,这就是F5工作的原因。