使用ajax和jsf渲染数据表列

时间:2014-03-11 15:36:46

标签: ajax jsf-2 datatable

我有一个数据表列出了一些具有几个细节的项目:

<h:dataTable id="versionInterfaces_datatable"
        styleClass="datatable" rowClasses="odd,even"
        value="#{versionToolManager.version.interfaces}"
        var="lInterface">

   <h:column>
      <f:facet name="header">Interface Name</f:facet>
      <h:commandLink id="versionInterfacesName_columnLink"
            value="#{lInterface.name}"
            action="#{interfaceManager.consult}">
        <f:setPropertyActionListener
              target="#{interfaceManager.interfaceEntity}"
              value="#{lInterface}" />
      </h:commandLink>
      <h:outputText id="versionInterfacesName_column" value="#{lInterface.name}" />
   </h:column>

   <h:column id="interfaceVersions_column">
       <f:facet name="header">Interface Version(s)</f:facet>
       <ui:repeat value="#{lInterface.versionsInterface}" var="lVersionI"
              varStatus="lStatus">
           <h:outputText rendered="#{lVersionI.versionsTools.contains(versionToolManager.version)}" value=" #{lVersionI.name} | " />
       </ui:repeat>
   </h:column>

   <h:column>
      <f:facet name="header">Interface Description</f:facet>
      <h:outputText id="versionInterfacesDescription_column"
           value="#{lInterface.description}" />
   </h:column>

然后我有一个按钮调用模态视图,允许添加项目:

<h:commandButton id="#{id}OpenModal_button"
   value="#{openButtonValue}"
  onclick="document.getElementById('#{formId}:#{modal_panel}').style.display='block'; return false;" />
<br />

关闭此模态视图时,我尝试&#34;刷新&#34;数据表以查看添加的项目:

    <h:commandButton id="#{id}CloseModal_button"
      value="#{closeButtonValue}">
      <f:ajax execute="@this"
        render="#{renderOnClose} #{formId}:#{modal_panel}" />
    </h:commandButton>

但我的数据表的列并未全部更新,列&#34;接口版本&#34;对于与新项目相对应的新行,它是空的,即使我保存时,它们已被很好地添加。

你有什么想法吗?

2 个答案:

答案 0 :(得分:0)

问题是<f:ajax execute="@this" ...

使用<f:ajax execute="@all" ...

答案 1 :(得分:0)

所以我成功地解决了我的问题,但这不是语法问题,而是模型和bean结构的错误使用。在没有详细说明的情况下,我试图获取与相应项目无关的数据。