次の html でわかるように、私のコードは、各行にフォームを含むデータからテーブルを生成します。フォームを送信すると、それがあった行に基づいてデータが投稿されます。これはうまく機能します。ただし、フィールドの初期データは行ごとに異なる必要があります。行が関連付けられているデータに基づいて計算された値である必要があります。これを設定するために使用できるdjangoテンプレートコードはありますか? または、ビューからその値を渡す方法はありますか?
{% for liquor in filter %}
<tr>
<td>{{ liquor.LiquorCode }}</td>
<td><a href="/liquors/get/{{ a.StoreID }}/{{ liquor.id }}/{{ SPI }}/">{{ liquor.BrandName }}</a></td>
<td>{{ liquor.VendorName }}</td>
<td>{{ liquor.LiquorType }}</td>
<td>{{ liquor.Proof }}</td>
<td>{{ liquor.BottleSize }}</td>
<td>{{ liquor.PackSize }}</td>
<td>{{ liquor.OffPremisePrice }}</td>
<td>{{ liquor.ShelfPrice }}</td>
<td>{{ liquor.GlobalTradeItemNumber1 }}</td>
<td><form action="/stores/quickadd/{{ a.StoreID }}/{{ liquor.id }}/{{ SPI }}/" method="post">{% csrf_token %}
{{form.as_p}}
<input type="submit" name="submit" value="Add to Store"></td>
</tr>
{% endfor %}
これが私の見解です:
def product_list(request, store_id):
store = Store.objects.get(StoreID=store_id)
f = ProductFilter(request.GET, queryset=Liquor.objects.all())
LiqSPI = StoreLiquor.objects.filter(storeID=store_id).count()
AddLiqForm = AddLiquorForm()
args = {}
args['filter'] = f
args['a'] = store
args['SPI'] = LiqSPI + 1
args['form'] = AddLiqForm
return render(request,'UPC_filter.html', args)
def quickadd(request, store_id, liquor_id, SPI):
storeID = Store.objects.get(StoreID=store_id)
liquorID = Liquor.objects.get(id=liquor_id)
if request.method == "POST":
AddLiqForm = AddLiquorForm(request.POST)
if AddLiqForm.is_valid():
StoreLiqID = AddLiqForm.save(commit=False)
StoreLiqID.storeID = storeID
StoreLiqID.liquorID = liquorID
StoreLiqID.StorePrice = request.POST.get('StorePrice', '')
StoreLiqID.SPI = SPI
StoreLiqID.save()
return HttpResponseRedirect('/stores/UPC_Scan/%s' % store_id)