0

我有一个 primeface 表,它显示来自存储在notificationList基于搜索的列表中的数据库中的数据。我希望在单击提交按钮后显示表格,但是在我添加渲染属性后,表格根本不显示。有人能告诉我我做错了什么以及如何解决吗?我尝试了两种方法来做到这一点。

  1. #{not empty notificationSearchBean.results.notificationList}即使列表不为空,使用也不起作用的 render= (我知道我在控制台中打印了结果)
  2. 创建一个称为可见的布尔值,如这篇文章“想要在单击按钮后显示填充数据的数据表”。无论可见设置为真还是假,这也不会显示表格。奇怪的是,我已经尝试用 true 初始化 visible 并且表格仍然没有被渲染。

这是我的表格代码:

 <h:panelGroup id = "table-wrapper" styleClass="searchResults">
    <h:form id="result" >
        <p:dataTable id="notTable" var="notifications" value="#{notificationSearchBean.results.notificationList}"  row="15">
            <p:column headerText="Notification No.">
                <h:outputText value="#{notifications.notificationNo}"/>
            </p:column>  
            <p:column headerText="Service">
                <h:outputText value="#{notifications.srvce}"/>
            </p:column>  
            <p:column headerText="Operation">
                <h:outputText value="#{notifications.oprtn}"/>
            </p:column>
            <p:column headerText="Service Version">         
                <h:outputText value="#{notifications.srvceVrsn}"/>
            </p:column>
            <p:column headerText="Event Date">
                <h:outputText value="#{notifications.evntDt}" >
                    <f:convertDateTime pattern="dd-MMM-yyyy 'at' HH:mm:ss.SSS" />
                </h:outputText>
           </p:column>
        </p:dataTable>                              
    </h:form>
</h:panelGroup>

以及提交按钮的代码:

<h:panelGrid align="center" columns="2">
    <p:commandButton value="Start Search" action="#{notificationSearchBean.getAllNotificationsForQuery}" update="table-wrapper"/> 
</h:panelGrid>

和 NotificationSearchBean:

@ManagedBean(name = "notificationSearchBean" )
@SessionScoped
public class NotificationSearchBean implements Serializable {

    private static final long serialVersionUID = 1L;
    private TransactionsDao transactionsDao = (TransactionsDao)((Login)FacesContext.getCurrentInstance().getExternalContext().getSessionMap().get("login")).getTransDao();
    @Inject
    private SearchCriteria search;
    @Inject 
    private ResultSet results; 

    @PostConstruct
    public void initialize() {
        //setting attributes for search form        
    }

    //getters and setters for search

    public ResultSet getResults() {
        return results;
    }

    public void setResults(ResultSet results) {
        this.results = results;
    }

    public String getAllNotificationsForQuery() {   
        List<NotificationLogT> notifications=transactionsDao.getAllNotifications(this.search);
        int temp=notifications.size();
        this.results.setNotificationList(notifications);

        if(temp==0){
            //prints out not results return message
        }
        return "success";
    }
}

还有 ResultSet 类:

public class ResultSet implements Serializable {
    private List<NotificationLogT> notificationList;
    private boolean visible = false;
    //private Integer dataSize;

    public boolean isVisible() {
        return visible;
    }

    public void setVisible(boolean visible) {
        this.visible = visible;
    }

    public List<NotificationLogT> getNotificationList() {
        setVisible(true);
        return notificationList;
    }

    public void setNotificationList(List<NotificationLogT> notificationList) {
        this.notificationList = notificationList;   
    }
}
4

0 回答 0