primefaces节省数据表编辑不工作

时间:2013-01-31 22:22:47

标签: jsf-2 primefaces cdi

我的xhtml页面。添加功能工作正常。所以转换器正在工作,并且由于ViewScope不工作,我尝试了SessionScope,它工作正常。

   <p:commandButton id="addOfficeButton"  icon="ui-icon-circle-plus"  oncomplete="AddOfficeDialog.show();"/>        

   <h:form  id="officeform"> 
    <p:growl id="growl" showDetail="true" sticky="true" />   
      <p:dataTable id="officeDT" var="office" value="#{offices}" rowKey="#{office.id}" style="width:40%"
                   selection="#{officeManagementController.selectedOffice}" selectionMode="single" editable="true">
        <p:ajax event="rowSelect" listener="#{officeManagementController.onRowSelect}" oncomplete="editDlg.show()"
                update=":tabView:officeform:growl,:tabView:officeform:editPanel"/> 
        <p:column sortBy="#{office.id}" headerText="Office ID">
            <h:outputText value="#{office.id}" />  
        </p:column>  

        <p:column headerText="System">     
               <h:outputText value="#{office.department.name}" />
        </p:column>  

        <p:column headerText="Section">     
               <h:outputText value="#{office.role.name}" rendered="#{office.role!=null}"/> 
        </p:column>  


        <p:column headerText="Options" style="width:50px"> 
           <p:rowEditor></p:rowEditor>    
        </p:column> 
      </p:dataTable>

      <p:dialog id="AddOfficeDialog" widgetVar="AddOfficeDialog" modal="true" header="Add/Edit Office" hideEffect="fade" showEffect="fade">
        <p:outputPanel layout="block" id="officeDetail">
         <p:panelGrid columns="2">

            <h:outputText value="Systemmm" />  
            <h:selectOneMenu value="#{officeManagementController.selectedSystem}" converter="#{applicationSystemConverter}">  
               <f:selectItem itemLabel="Select One" itemValue="#{null}" />  
               <f:selectItems value="#{departmentss}" var="appdepartment" itemLabel="#{appdepartment.name}" itemValue="#{appdepartment}"/> 
               <f:ajax event="change" listener="#{officeManagementController.onDepartmentChanged}" render="role"/> 
            </h:selectOneMenu> 

            <h:outputText value="Section" />  
            <h:selectOneMenu id="role" validate="true" value="#{officeManagementController.newOffice.role}" converter="#{departmentSectionConverter}">  
               <f:selectItem itemLabel="Select One" itemValue="#{null}" />  
               <f:selectItems value="#{officeManagementController.assignableRoles}" var="role" itemLabel="#{role.name}" itemValue="#{role}"/>  
            </h:selectOneMenu> 


         </p:panelGrid>
         <p:outputPanel layout="block" style="text-align:center;">
            <p:commandButton actionListener="#{officeManagementController.createOffice}" id="addOffice"  
                             value="Add Office" title="Add new office" oncomplete="AddOfficeDialog.hide();" update="growl,officeform"/>  
         </p:outputPanel>
        </p:outputPanel>
      </p:dialog>

       <p:dialog id="editDlg" widgetVar="editDlg" modal="true"  header="Add/Edit Office" hideEffect="fade" showEffect="fade">
       <p:outputPanel  id="editPanel">
         <p:panelGrid columns="2">
          <h:outputLabel value="Office ID: " />
            <h:outputText  value="#{officeManagementController.selectedOffice.id}"/>


            <h:outputText value="System" />  
            <h:selectOneMenu value="#{officeManagementController.selectedOffice.department}" converter="#{applicationSystemConverter}">  
               <f:selectItem itemLabel="Select One" itemValue="#{null}" />  
               <f:selectItems value="#{applicationSystems}" var="appdepartment" itemLabel="#{appdepartment.name}" itemValue="#{appdepartment}"/> 
               <f:ajax event="change" listener="#{officeManagementController.onApplicationSystemChanged}" render="sect"/> 
            </h:selectOneMenu> 

            <h:outputText value="Section" />  
            <h:selectOneMenu id="sect" validate="true" value="#{officeManagementController.selectedOffice.role}" converter="#{departmentSectionConverter}">  
               <f:selectItem itemLabel="Select One" itemValue="#{null}" />  
               <f:selectItems value="#{officeManagementController.assignableSysSections}" var="role" itemLabel="#{role.name}" itemValue="#{role}"/>  
            </h:selectOneMenu> 

           </p:panelGrid>
           <p:outputPanel layout="block" style="text-align:center;">
           <h:inputHidden binding="#{officeManagementController.selectedOfficeId}" />
          <p:commandButton actionListener="#{officeManagementController.updateOffice()}" 
                    value="Update Office" title="Update office" oncomplete="editDlg.hide();" update="@this,editPanel,growl,officeform"/>  
            </p:outputPanel>
         </p:outputPanel>
      </p:dialog>

   </h:form>

支持Bean:

    public void updateOffice() {
        selectedOffice.setId(Long.valueOf((String)selectedOfficeId.getValue()));
        officeManagementService.update(selectedOffice);
        facesContext.addMessage(null, new FacesMessage(FacesMessage.SEVERITY_INFO, CrudStatusMessage.SUCCESS.toString(), "Successfully updated Module: " + selectedOffice.getName()));
    }

我正在使用行值填充对话框,但问题是点击更新按钮,我在dept上得到Value is not Valid错误,但主要的是未设置selectedModule的值。请帮忙。坚持了一周。

2 个答案:

答案 0 :(得分:0)

我认为你的按钮实际上需要actionListener(而不是action)。您应该阅读API文档中的差异,但最重要的是actionListener将执行AJAX回发,而操作将导致重定向(反过来将破坏您的视图并用新的视图替换它)。

答案 1 :(得分:0)

首先,您不需要()

<p:commandButton action="#{officeManagementController.updateOffice}" value="Update Office" title="Update office" oncomplete="editDlg.hide();" update="@this,editPanel,growl,officeform"/>  

尝试使用<f:ajax/>中的<h:selectOneMenu>并检查其是否有效。