我正在尝试制作一个表格,在列表中显示一个组中的所有产品。可以给它们一个数量并添加到报价中。然后将其存储在数据库中。
没有一个自动表单选项对我有用。所以我让每一行都显示给定产品的信息,带有数量框和一个添加项目按钮,它是自己的表单。但是使每种形式的循环都在做一些奇怪的事情。
控制器:
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)
但这仅命名了一种形式,而另一种仍命名为“默认”。