当我点击取消请求的链接时,我希望我的表单包含带有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);
}
答案 0 :(得分:0)
正如Luiggi所说 - 嵌套表格无效。
参考SO: Can you nest html forms? 看看你的设计是否真的需要嵌套内部形式,或者只是使用部分ajax更新来满足你的需求。