2012-01-03 2 views
0

В моем продукте используется JSF с Primefaces 2.2. То, что мне нужно, - это обработать поддиффутируемый внутри другого datatable. Код выглядит следующим образом.Привязка подзаголовка внутри данных с JSF

<h:form> 
<p:dataTable id="myInvoiceTable" 
    value="#{globalBean.invoices}" var="invoice"> 

    <p:column> 
     <f:facet name="header"> 
     <h:outputText value="Bill ID" /> 
     </f:facet> 
     <h:outputText value="#{invoice.billId}" /> 
    </p:column> 

    <p:column> 
     <f:facet name="header"> 
     <h:outputText value="Item" /> 
     </f:facet> 
     <h:outputText value="#{invoice.item}" /> 
    </p:column> 

    <p:rowExpansion> 

     <h:selectOneMenu id="reasons" value="#{invoiceAction.reason}"> 
     <f:selectItem itemLabel="Reason 1" itemValue="Reason 1"></f:selectItem> 
     <f:selectItem itemLabel="Reason 2" itemValue="Reason 2"></f:selectItem> 
     </h:selectOneMenu> 

     <p:inputText id="activity_amount" value="#{invoiceAction.activity_amount}"/> 

     <p:commandButton value="PROCESS" action="invoice_process" update="actions_table"> 
     </p:commandButton> 

     <p:dataTable id="actions_table" value="#{invoice.actions}" var="invAction"> 

     <p:column> 
      <h:outputText value="#{invAction.reason}" /> 
     </p:column> 

     <p:column>    
      <h:outputText value="#{invAction.activity_amount}" /> 
     </p:column> 

     </p:dataTable> 

    </p:rowExpansion> 

</p:dataTable> 

Вот мой боб.

public class Invoice { 
    private int billId; 
    private String item; 
    private List<InvoiceAction> actions; 

    // Getter & setter here 
} 

public class InvoiceAction { 
    private String reason; 
    private double activity_amount; 
    private int billId; 

    // Getter & setter here; 
} 

Но когда HTML сгенерирован, он не обрабатывается по желанию. Только выбранное меню в последней строке данных может получать данные, выбранные пользователем, другие не могут. Поскольку все выбранные меню во всех строках используют один и тот же объект (# {invoiceAction}), а компонент только получает значение последнего компонента на странице. Я знал причину, но не знаю, как ее решить. Как отправить их в указанную строку?

ответ

1

Прежде всего, я думаю, что ваши классы Invoice и InvoiceAction выглядят так же, как обычные объекты Java. Я чувствую, что они не должны управляться Bean.

Кроме того, вы правы, что ваш #{invoiceAction} неправильно привязан к одному из действий в List<InvoiceAction> actions. Поскольку вы используете вложенный <p:dataTable>, я думаю, вы можете воспользоваться <p:cellEditor>. Это было бы примерно так:

<p:rowExpansion> 
    <p:dataTable id="actions_table" value="#{invoice.actions}" var="invAction"> 

     <p:column> 
     <p:cellEditor> 
      <f:facet name="output"> 
       <h:outputText value="#{invAction.reason}" /> 
      </f:facet> 
      <f:facet name="input"> 
       <h:selectOneMenu id="reasons" value="#{invoiceAction.reason}"> 
        <f:selectItem itemLabel="Reason 1" itemValue="Reason 1" /> 
        <f:selectItem itemLabel="Reason 2" itemValue="Reason 2" /> 
       </h:selectOneMenu> 
      </f:facet> 
     </p:cellEditor> 
     </p:column> 

     <p:column> 
     <p:cellEditor> 
      <f:facet name="output"> 
       <h:outputText value="#{invAction.activity_amount}" /> 
      </f:facet> 
      <f:facet name="input"> 
       <p:inputText id="activity_amount" value="#{invoiceAction.activity_amount}" /> 
      </f:facet> 
     </p:cellEditor> 
     </p:column> 

    </p:dataTable> 

    <p:commandButton value="PROCESS" action="invoice_process" update="actions_table" /> 
</p:rowExpansion>