我试图将get参数从分配给我按钮的上一页传递到下一页,将其添加到表单中并将其保存在数据库中。我的代码如下:
views.py
def massage_order(request):
parametr_html_product_name = request.GET('parameter')
if request.method == 'POST' and 'btn_massage_order' in request.POST:
ordering_form = OrderingMassageForm(data=request.POST)
if ordering_form.is_valid():
massage_product = parametr_html_product_name
[...]
else:
ordering_form = OrderingMassageForm()
templates.html
<a href="{% url 'app:massage_order' %}?parameter={{ product.name }}¶meter_1={{ product.price }}¶meter_2={{ product.time }}¶meter_3={{ masseur.name }}">
<div class="btn-group btn-action-label" role="group" aria-label="Like">
<div class="btn btn-sm btn-outline-primary btn-label">{{ product.price }} zł/ {{ product.time }} min</div>
<button type="button" class="btn btn-sm btn-primary btn-action">
<span>Zamów masaż</span>
</button>
</div>
</a>
但是,每次“多值字典键错误”我发现他的解决方法parametr_html_product_name = request.GET.get('parameter', False)
时,我都会收到一个错误
但是在这种情况下,我的变量为False,而不是产品名称(预期的名称)。如何将变量“ html参数产品名称”传递给表单?我试图将其添加到列表中(也没有积极作用)。任何帮助将不胜感激。
为什么尽管在Django列表中添加了一个变量,但在我的表单中却看不到它?
list = [parametr_html_masseur_name, parametr_html_product_name]
[...]
massage_product = list[1]
[...]
编辑
templates.html
<form action="." method="post">
<input type="hidden" name="name" value="{{ product.name }}">
<input type="hidden" name="name" value="{{ product.price }}">
<input type="hidden" name="name" value="{{ product.time }}">
{% csrf_token %}
<div class="btn-group btn-action-label" role="group" aria-label="Like">
<div class="btn btn-sm btn-outline-primary btn-label">{{ product.price }} zł/ {{ product.time }} min</div>
<button type="submit" name="hidden_btn" class="btn btn-sm btn-primary btn-action">
<span>Zamów masaż</span>
</button>
</div>
</form>
forms.py
class HiddenOrderingMassageForm(forms.Form):
product_name = forms.CharField(widget=forms.HiddenInput)
price = forms.IntegerField(widget=forms.HiddenInput)
time = forms.IntegerField(widget=forms.HiddenInput)
views.py
if request.method == 'POST' and 'hidden_btn' in request.POST:
hidden_form = HiddenOrderingMassageForm(request.POST)
if hidden_form.is_valid():
product_name = hidden_form.cleaned_data['product_name']
return HttpResponseRedirect(reverse('app:massage_order', args=[product_name]))
else:
hidden_form = HiddenOrderingMassageForm()
urls.py
url(r'^massage_order/(?P<text>[\w\-]+)/$', views.massage_order, name='massage_order')
答案 0 :(得分:1)
在当前代码中,您正在使用GET
(所有内容都包装在<a>
标记中),但是您希望这些值位于request.POST
中。我认为最好的方法是使用带有隐藏输入的表单,并根据需要输入所有值,然后像在表单上一样在后端对其进行验证。因此,不要使用a
,而是改为以下内容:
<form action="{% url 'app:massage_order' %}" method="post">
<input type="hidden" name="name" value="product_name">
...
{% csrf_token %}
<div class="btn-group btn-action-label" role="group" aria-label="Like">
<div class="btn btn-sm btn-outline-primary btn-label">{{ product.price }} zł/ {{ product.time }} min</div>
<button type="button" class="btn btn-sm btn-primary btn-action">
<span>Zamów masaż</span>
</button>
</div>
</form>
或者,您可以指定一个OrderingMassageForm
,而不是在模板中手动创建表单,而该字段会将所有字段的小部件设置为隐藏输入,即:
class HiddenOrderingMassageForm(forms.Form):
product_name = forms.CharField(widget=forms.HiddenInput)
,然后以通常的方式放入模板:
<form action="{% url 'app:massage_order' %}" method="post">
{{ hidden_form }}
{% csrf_token %}
<div class="btn-group btn-action-label" role="group" aria-label="Like">
<div class="btn btn-sm btn-outline-primary btn-label">{{ product.price }} zł/ {{ product.time }} min</div>
<button type="button" class="btn btn-sm btn-primary btn-action">
<span>Zamów masaż</span>
</button>
</div>
</form>