我正在将Primefaces 6.2与MyFaces 2.2一起使用。 fileUpload组件部分正常工作,调用了listener方法并保存了文件,但update属性不会触发数据表自动重新呈现。我必须手动刷新页面才能使上传的文件显示在数据表中。
这是视图:
<h:form id="uploadForm" enctype="multipart/form-data">
<p:outputPanel id="uploadPanel" style="float : left; width : 700px; padding-top : 20px">
<p:fileUpload id="uploadComponent" fileUploadListener="#{userDocsManagedBean.uploadListener}" mode="advanced" update="userDocsTbl" />
</p:outputPanel>
<p:outputPanel id="docsPanel" style="float : left; width : 700px; padding-left : 20px; padding-top : 20px" layout="block">
<p:dataTable id="userDocsTbl"
value="#{userDocsManagedBean.files}"
var="f"
rows="10"
scrollable="true"
scrollWidth="590"
scrollHeight="335"
style="width:590px; height:350px;"
rowHover="true" >
<f:facet name="header">
<h:outputText value="User Generated Documents" style="font-size: 16px" />
</f:facet>
<p:column headerText="File Name" styleClass="alignLeft" width="330px" sortBy="#{f.fileName}">
<h:outputLink value="#{f.fileName}" onclick="window.open('#{f.fileName}?p1=#{f.path}','pdf').target='_blank';return false;">#{f.fileName}</h:outputLink>
</p:column>
<p:column headerText="Date Modified" styleClass="alignCenter" width="160px" sortOrder="#{userDocsManagedBean.sortOrder}" sortBy="#{f.dateModified}">
<h:outputText value="#{f.dateModified}" />
</p:column>
<p:column headerText="Size" styleClass="alignCenter" width="80px" sortBy="#{f.size}">
<h:outputText value="#{f.size}" />
</p:column>
</p:dataTable>
</p:outputPanel>
</h:form>
这是侦听器方法(bean是viewscoped的):
public void uploadListener(FileUploadEvent event) {
UploadedFile file = event.getFile();
uploadFile(file);
FacesContext ctxt = FacesContext.getCurrentInstance();
Collection<String> ids = ctxt.getPartialViewContext().getRenderIds();
ids.add("uploadForm:userDocsTbl");
}
答案 0 :(得分:0)
PrimeFaces fileUpload更新属性按预期方式工作,并且在侦听器方法中不需要多余的代码(将组件ID添加到上下文中)。
问题是Eclipse中的Liberty Profile服务器由于内部错误而未更新/发布其应用程序副本,因此该应用程序与源代码不同步。一旦修复,它就会按预期工作。