p:dataTable - 删除行后刷新数据表

时间:2012-08-06 13:35:47

标签: java jsf java-ee jsf-2 primefaces

以下是我的数据表pic,我希望当我删除一行时,数据表刷新。但是从DB中删除了行,但之后没有从数据表中删除。 enter image description here 我尝试下面的代码,但他们无法帮助我。

<h2>مشاهده اطلاعات پرسنل</h2>   
 <h:form id="f2" prependId="false">  

    <p:dataTable id="pdataTable" var="personel" value="#{personelMB.personelList}" rowKey="#{personelMB.personel_id}"
    >  

        <f:facet name="header">  
            اطلاعات پرسنل 
        </f:facet>  

        <p:column>  
            <f:facet name="header">  
               شماره پرسنلی  
            </f:facet>  

            <h:outputText value="#{personel.personel_id}" />  

            <f:facet name="footer">  
                کدملی 
            </f:facet>  
        </p:column>  

        <p:column headerText="نام">  
            <h:outputText value="#{personel.pname}" />  
        </p:column>  

        <p:column headerText="نام خانوادگی">  
            <h:outputText value="#{personel.pfamily}" />  
        </p:column>  

        <p:column headerText="آدرس">  
            <h:outputText value="#{personel.paddress}" />  
        </p:column>  
   <p:column headerText="تلفن">  
            <h:outputText value="#{personel.pphone}" />  
        </p:column>
        <p:column>
      <f:facet name="حذف">
         <h:outputText value="" />
      </f:facet>
      <p:commandButton icon="ui-icon-close" title="حذف"
                       actionListener="#{personelMB.deletePersonel(personel.personel_id)}" update="pdataTable"/>
   </p:column>
        <f:facet name="footer">  
            تعداد رکورد#{fn:length(personelMB.getPersonelList())} میباشد.  
        </f:facet>  

    </p:dataTable>  

</h:form> 

2.第二次尝试:

<p:commandButton icon="ui-icon-close" title="حذف"
 actionListener="#{personelMB.deletePersonel(personel.personel_id)}" reRender="pdataTable"/>
                   </p:column>

3.第三次尝试: personelBean.java

public void deletePersonel(int personel_id){
        Personel personel=(Personel)personelservice.getPersonelId(personel_id);
        getPersonelservice().deletePersonel(personel);
    }
    public String deleteAction(Personel personel) {
        personelList.remove(personel);
        return null;
      }

xhtml文件

<p:commandButton icon="ui-icon-close" title="حذف"
                       actionListener="#{personelMB.deletePersonel(personel.personel_id)}" action="#{personelMB.deleteAction(personel)}"/>
   </p:column>

请帮帮我。

3 个答案:

答案 0 :(得分:6)

而不是ajax是假的,这是真的。

actionListener="#{personelMB.deletePersonel(personel.personel_id)}"  update="@form" ajax="true"/>

答案 1 :(得分:0)

使用update =&#34; @ form&#34; commandbutton上的参数

答案 2 :(得分:0)

你在

中尝试过这样吗?
 <p:commandButton update=":f2:pdataTable"></p:commandButton>