1

我已经在 SO 和其他地方阅读了有关我的问题的信息。

我明白我在做的是完全错误的。我的问题是我不知道如何正确地做,如果有人可以帮助我,我会很高兴。

目前我所拥有的看起来像这样:

<ul class="unstyled">   
    <ui:repeat value="#{paymentDetailsBean.products}" var="product" varStatus="status">
        <li>
            <div>
                <h:selectBooleanCheckbox value="#{product.initiallySelected}">
                    <f:ajax render="paymentDetailsForm:totalPriceText" listener="#{paymentDetailsBean.updateTotalPrice}"></f:ajax>
                </h:selectBooleanCheckbox>
            </div>
        </li>
    </ui:repeat>
</ul>

product.initiallySelected是我希望在用户选中/取消选中产品时更新的布尔值。

我还使用 ajax 标签来重新渲染:

<h:outputText id="totalPriceText"><b>#{passengerDetailsBean.formatCurrency(paymentDetailsBean.totalPrice.toString())}</b></h:outputText>

基本上我希望总价不被更新,因为选择/取消选择产品会使其上升或下降。我也在使用 ajax 标签(这显然是问题所在)在后端调用这个函数:

public void updateTotalPrice(AjaxBehaviorEvent event)
{
    this.totalPrice = 0.0f;

    for (Product product : this.getProducts())
    {
        if (product.getInitiallySelected())
        {
            this.totalPrice += product.getCurrencyAmountGroup().getAmount();
        }
    }

    this.totalPrice += this.getTotalFaresAmount();
}

所有这些都有效,但它非常慢,我知道这是因为我不应该使用 ajax 标签来做业务逻辑。我不知道正确的做法。有人可以帮我吗?

4

1 回答 1

1

如果您想通过选中/取消选中特定产品来增加/减少总价值,并假设您的环境支持 EL 2.2+(从您的代码段判断是真的),您可以将当前金额存储为 bean 属性并增加/减少它取决于当前选择的产品和复选框的当前值:

<ui:repeat value="#{paymentDetailsBean.products}" var="product">
    <li>
        <div>
            <h:selectBooleanCheckbox>
                <f:ajax render=":paymentDetailsForm:totalPriceText" 
                        listener="#{paymentDetailsBean.updateTotalPrice(product, component.value)}" />
            </h:selectBooleanCheckbox>
        </div>
    </li>
</ui:repeat>
<h:outputText value="#{paymentDetailsBean.totalPrice}" />

与听众:

public void updateTotalPrice(Product product, Boolean direction) {
    totalPrice += product.getCurrencyAmountGroup().getAmount() *
                       (direction ? 1 : -1);
}
于 2013-10-22T14:52:45.607 回答