编辑后数据列表不刷新

时间:2016-07-12 05:54:09

标签: jsf master-detail ajax-update

我想在编辑元素后刷新datalist。我使用了@Postconstruct来初始化数据,但是徒劳无功。

以下代码显示数据列表:

<h:form>

  <p:dataTable widgetVar="developpeur" value="#{manageUrlSiteTestBean.sitewebs}" var="dev"   style="margin-bottom:20px">
 <f:facet name="header">
Les tests de la website url </f:facet>

   <p:column headerText="titre">
 #{dev.title}
 </p:column>


 <p:column>
 <p:commandButton value="edit"  update=":form">
  <f:setPropertyActionListener target="#{manageUrlSiteTestBean.siteweb}" value="#{dev}"></f:setPropertyActionListener>
   <f:setPropertyActionListener target="#{manageUrlSiteTestBean.form}" value="true"></f:setPropertyActionListener>
 </p:commandButton>
 </p:column>
 </p:dataTable>
 </h:form>

代码的第二部分是一个检索选择进行编辑的数据的表单

<h:panelGrid id="form">

 <h:form rendered="#{manageUrlSiteTestBean.form}" >
 <p:panel header="Modification">
 <h:panelGrid columns="1">

 <p:outputLabel value="Name" id="lcin"/>
 <p:inputText id="cink" value="#{manageUrlSiteTestBean.siteweb.title}" required="true" >
 </p:inputText>

  </h:panelGrid>
 <p:commandButton value="Validate" action="#{manageUrlSiteTestBean.validate()}" />
  </p:panel>
  </h:form>
 </h:panelGrid> 

以下代码是支持bean

@ManagedBean
@ViewScoped
public class ManageUrlSiteTestBean implements Serializable{

    public ManageUrlSiteTestBean(){

    }
    private static final long serialVersionUID = 1L;
    @EJB
    ManageUrlSiteTestLocal local;
    private SiteWebImpose siteweb = new SiteWebImpose() ;
    private List<SiteWeb> sitewebs=new ArrayList<SiteWeb>();
    private boolean form;
    public ManageUrlSiteTestLocal getLocal() {
        return local;
    }
    public void setLocal(ManageUrlSiteTestLocal local) {
        this.local = local;
    }
    public List<SiteWeb> getSitewebs() {
        return sitewebs;
    }
    public void setSitewebs(List<SiteWeb> siteweb) {
        this.sitewebs = siteweb;
    }
    public SiteWebImpose getSiteweb() {
        return siteweb;
    }
    public void setSiteweb(SiteWebImpose siteweb) {
        this.siteweb = siteweb;
    }   
    public boolean isForm() {
        System.out.println("nn");
        return form;
    }
    public String validate(){
        local.updateUrlSite(siteweb);
        form=false;
        siteweb=new SiteWebImpose() ;
        init();
        return null;        
    }
    public void setForm(boolean form) {
        this.form = form;
    }   
    @PostConstruct
    public void init(){
        setSitewebs(local.listerUrlSiteTests());
    }
}

我怎样才能做到这一点?

1 个答案:

答案 0 :(得分:0)

当您触发按钮的验证操作时,您实际上并未更新列表。所以列表会更新,好的,但是你需要在html上更新它。试试这样的

<p:commandButton value="Validate" action="#{manageUrlSiteTestBean.validate()}" update=":form:developpeur"/>

我不记得你是否必须声明你的数据表的id或它只适用于widgetVar,但我认为你也需要一个id,所以也把id="developpeur"放在你的dataTable上。 并在第一个表单中添加id="form"

看一下这里关于ajax submit和non-ajax submit

的例子

http://www.primefaces.org/showcase/ui/button/commandButton.xhtml