1

我正在尝试制作一个表格,在列表中显示一个组中的所有产品。可以给它们一个数量并添加到报价中。然后将其存储在数据库中。

没有一个自动表单选项对我有用。所以我让每一行都显示给定产品的信息,带有数量框和一个添加项目按钮,它是自己的表单。但是使每种形式的循环都在做一些奇怪的事情。

控制器:

products = db(db.product.group_id == productgroupnumber).select()
forms=[]
for product in products:
    form = FORM(TABLE(TR(TD(product.productname),
                         TD((product.purchasecost or 0)),
                         TD((product.monthlycost or 0)),
                         TD(INPUT(_type='number', _name='quantity')),
                         TD(INPUT(_type='submit', _value=T('Add to Offer')))
                         )
                      )
                )
    forms.append(form)

session.quotedproducts = []
if form.accepts(request, session, keepvalues = True):
    product = db(db.product.id == product_id).select().first()
    offeritem = [product_id, request.vars.quantity, product.purchasecost, product.monthlycost]
    session.quotedproducts.append(offeritem)
    response.flash = T("Item added to offer")`

为 2 行。视图有以下 2 种形式,只有一个隐藏的 div 带有 formkey 和 formname。所以我不能命名表格以便正确处理它们:

<form action="#" enctype="multipart/form-data" method="post">
    <table>
        <tr>
           <td>Block of 10 Phone Numbers</td>
           <td>19.0</td>
           <td>0</td>
           <td><input name="quantity" type="number" /></td>
           <td><input type="submit" value="Add to Offer" /></td>
       </tr>
    </table>
</form>     

<form action="#" enctype="multipart/form-data" method="post">
    <table>
        <tr>
            <td>100 Block of Phone Numbers</td>
            <td>149.0</td>
            <td>0</td>
            <td><input name="quantity" type="number" /></td>
            <td><input type="submit" value="Add to Offer" /></td>
        </tr>
    </table>

<!--Why is there only one of these??--> 
    <div style="display:none;">
        <input name="_formkey" type="hidden" value="b99bea37-f107-47f0-9b1b-9033c15e1193" />
        <input name="_formname" type="hidden" value="default" />
    </div>
</form>

我如何为表格提供个人名称(最好是 product.id)?我尝试添加 formname 参数:

form.accepts(request, session, formname=product.id)

但这仅命名了一种形式,而另一种仍命名为“默认”。

4

1 回答 1

0

在您的代码中,您在循环中创建多个表单for,但在退出循环后,您调用form.accepts(). 此时, 的值form是循环中创建的最后一个表单,因此只处理该表单。

请注意,当最初创建表单时,form.accepts(或首选form.process)方法将 the_formname_formkeyhidden 字段添加到表单(这些用于 CSRF 保护)。在表单提交后调用相同的方法时,它还会处理表单验证。因此,鉴于您的工作流程,您必须在创建和提交时处理所有表单。也许是这样的:

products = db(db.product.group_id == productgroupnumber).select()
forms = []
for product in products:
    quantity_name = 'quantity_%s' % product.id
    form = FORM(TABLE(TR(TD(product.productname),
                         TD((product.purchasecost or 0)),
                         TD((product.monthlycost or 0)),
                         TD(INPUT(_type='number', _name=quantity_name)),
                         TD(INPUT(_type='submit', _value=T('Add to Offer')))
                         )
                      )
                )
    if form.process(formname=product.id, keepvalues=True).accepted:
        offeritem = [product.id, form.vars[quantity_name],
                     product.purchasecost, product.monthlycost]
        session.quotedproducts.append(offeritem)
        response.flash = T("Item added to offer")
    forms.append(form)
于 2016-11-08T15:51:50.217 回答