Primefaces - 如何从另一个表单更新动态的.xhtml表单

时间:2014-05-28 20:16:20

标签: forms jsf jsf-2 primefaces

当我点击取消请求的链接时,我希望我的表单包含带有commandLink的表单以动态更新(因为此记录不再以此形式显示)。这是我的代码:

<h:form id = "form">
        <p:dataGrid id = "dataGrid" value="#{userRequestBean.userActiveRequests}" columns="1"
            var="userActiveRequest" selection="#{userRequestBean.request}"
            rowKey="#{userActiveRequest.id}">
            <f:facet name="header">
            My requests
        </f:facet>

            <h:panelGrid id="panelGrid">
                <h:outputText value="#{userActiveRequest.title.toUpperCase()}" />
                <h:outputText value="#{userActiveRequest.description}" />

                <h:form rendered="#{not empty userActiveRequest.hiredAgency}">
                    <h:commandLink
                        value="Details for agency #{userActiveRequest.hiredAgency.tUser.name}"
                        action="agencyDetail?faces-redirect=true">
                        <f:setPropertyActionListener target="#{agencyBean.tAgency}"
                            value="${userActiveRequest.hiredAgency}" />
                    </h:commandLink>
                </h:form>
**//HERE IS THE COMMANDLINK WHICH I MENTIONED**
                <h:form rendered="#{empty userActiveRequest.hiredAgency}">
                    To cancel, click <p:commandLink
                        value="HERE" action="#{userRequestBean.cancelRequest()}"
                        update = "form:dataGrid:panelGrid">
                        <f:setPropertyActionListener target="#{userRequestBean.request}"
                            value="${userActiveRequest}" />
                    </p:commandLink>
                </h:form>

                <p:commandButton value="Details"
                    action="userRequestDetails?faces-redirect=true">
                    <f:setPropertyActionListener target="#{userRequestBean.request}"
                        value="${userActiveRequest}" />
                </p:commandButton>
            </h:panelGrid>
        </p:dataGrid>
    </h:form>

增加: Java类的一部分:

private List<TRequest> userActiveRequests; // + get and set methods

    public UserRequestBean(){
        EntityManager em = HibernateUtil.getEntityManager();
        Query query = em.createQuery("select r " +
                "from TUser u join u.userRequests r where u.id = :userId and r.isActive = 'Y'");
        query.setParameter("userId", Long.valueOf(11));
        userActiveRequests = query.getResultList();
    }

    public void cancelRequest (){
        EntityManager em = HibernateUtil.getEntityManager();
        em.getTransaction().begin();
        request.setIsCancelled(true);
        request.setIsActive(false);
        em.merge(request);
        em.getTransaction().commit();
        //remove the object from the List
        userActiveRequests.remove(request);
    }

1 个答案:

答案 0 :(得分:0)

正如Luiggi所说 - 嵌套表格无效。

参考SO: Can you nest html forms? 看看你的设计是否真的需要嵌套内部形式,或者只是使用部分ajax更新来满足你的需求。

相关问题