2017-07-08 47 views
5

Primefaces tablosu için düzenleme formu oluşturmak istiyorum.Primefaces tablosu için form oluştur

<h:form id="form"> 
    <p:dataTable id="tbl" var="systemuser" value="#{systemusers.systemUsers}"         
       selectionMode="single" selection="#{systemusers.selectedSystemUser}" rowKey="#{systemuser.username}" lazy="true" 
       resizableColumns="true" 
       > 

     <p:ajax event="rowSelect" listener="#{systemusers.onRowSelect}" update=":form:carDetail" oncomplete="PF('carDialog').show()" /> 
     .................... 
    </p:dataTable> 

    <p:dialog id="wd" header="System User Details" widgetVar="carDialog" modal="true" showEffect="fade" hideEffect="fade" resizable="true"> 
     <p:outputPanel id="carDetail" style="text-align:center;"> 
      <p:panelGrid columns="2" columnClasses="label,value"> 

       <h:outputLabel for="id" value="ID" /> 
       <p:outputLabel id="id" value="#{systemusers.selectedSystemUser.id}" rendered="#{not systemusers.editable}"/> 
       <h:inputText value="#{systemusers.selectedSystemUser.id}" rendered="#{systemusers.editable}" /> 
       ........ 
      </p:panelGrid> 
     </p:outputPanel> 

     <f:facet name="footer"> 
      <p:commandButton value="Edit System User" rendered="#{not systemusers.editable}" 
          actionListener="#{systemusers.editRecord(false)}"> 
       <f:ajax render=":form:wd" execute=":form:wd"></f:ajax> 
      </p:commandButton>&nbsp; 

      <p:commandButton value="Cancel" rendered="#{systemusers.editable}" actionListener="#{systemusers.editRecord(true)}"> 
       <f:ajax render=":form" execute=":form"></f:ajax> 
      </p:commandButton> 
     </f:facet> 
    </p:dialog> 

    <p:contextMenu for="tbl"> 
     <p:menuitem value="View" update="carDetail" icon="fa fa-search" oncomplete="PF('carDialog').show()"/> 
     <p:menuitem value="Delete" update="tbl" icon="fa fa-remove" actionListener="#{systemusers.deleteSystemUser}"> 
      <p:confirm header="Confirmation" message="Are you sure?" icon="fa fa-warning" /> 
     </p:menuitem> 
    </p:contextMenu> 

    <p:confirmDialog global="true" showEffect="fade" hideEffect="fade"> 
     <p:commandButton value="Yes" type="button" styleClass="ui-confirmdialog-yes" icon="fa fa-check" /> 
     <p:commandButton value="No" type="button" styleClass="ui-confirmdialog-no" icon="fa fa-remove" /> 
    </p:confirmDialog> 
</h:form> 

Yönetilen fasulye: Ben Düzenleme Formu açmak ve düğme Edit System User tıkladığınızda

@Named 
@RequestScoped 
public class Systemusers implements Serializable 
{ 
....... 
public void editRecord(boolean editable) 
    { 
     SessionFactory factory = HibernateUtils.getSessionFactory(); 
     Session session = factory.getCurrentSession(); 

     try 
     { 
      session.getTransaction().begin(); 

      SystemUsersModel obj = new SystemUsersModel(); 
      obj.setId(selectedSystemUser.getId()); 
      .......... 
      session.update(obj); 

      session.getTransaction().commit(); 

      this.editable = editable; 
     } 
     catch (Exception e) 
     { 
      e.printStackTrace(); 
      session.getTransaction().rollback(); 
     } 
    } 
...... 
private boolean editable = false; 

    public boolean isEditable() 
    { 
     return editable; 
    } 

    public void setEditable(boolean editable) 
    { 
     this.editable = editable; 
    } 
} 

formu kaybolur Bu kodu test etti. Muhtemelen bunu yapıp çalıştırdığımdan. Formu kapatmadan ve altından nasıl uygulayabilirim?

+0

olmalıdır. Bunu denedim ancak aynı sonucu alıyorum. Bir kod örneği yapıştırabilir misin? –

+0

Teklifinizi denedim, ancak yine de iletişim kutusu gizlendi. Diyaloğa form ekledim ve şu an için sorunu çözmeyi başardım. Şu anda bu sorunla karşı karşıyayım: Java Nesne değeri = "# {systemusers.selectedSystemUser.id}" boş, daha sonra düzenleme düğmesine basıyorum. Bunu nasıl düzeltebilirim? –

+0

Burada kısa bir not, iletişim kutusu için özel bir h: formuna sahip olmanız ve bir tane için daha iyi bir tabloya sahip olmanızdır: p: iletişiminin içeriğini ** yeni bir h: formuyla sarmayı deneyin ve verilerinizi eski ile birlikte saklayın h: form, bu herhangi bir yanlış yürütme veya işlem sorununu gidermenize yol açabilir. –

cevap

1

Örnek kod, birçok yolla bozuk. İki şey öne çıkmaktadır:

  • O olmayan bir [MCVE]
  • <f:ajax render=":form" execute=":form"> gereksiz olduğu, hatta tuhaf davranışlar neden olabilir

OP büyük olasılıkla PrimeFaces showcase o (alıntı bilmez, vurgu benim)

KomutDüğmesi

KomutDüğmesi, standart h: commandButton ajax, kısmi işleme ve kaplama özellikleriyle genişletir.

Yani commandBotton zaten ajax olarak çalıştırılır ve içindeki bir

<f:ajax render=":form" execute=":form"> 

Hava etmek gerek yok. Bu (büyük olasılıkla) güncellemenin iki kez yapılmasını sağlar. Bir @ none (Understanding PrimeFaces process/update and JSF f:ajax execute/render attributes) ve bir tanesi form güncelleniyor. İkincisinin büyük olasılıkla içeriği yok. Fakat denemek (ve hata ayıklamak) işleri netleştirecektir. Bu cevap değilse, neden kodda görülemez ve dolayısıyla bir [mcve]