提交时手动渲染的 Django 表单集重定向问题



我定义了以下模型:

class Item(models.Model):
rfid_tag    = models.CharField()
asset       = models.OneToOneField('Assets', default=None, null=True,
on_delete=models.SET_DEFAULT,)
date        = models.DateTimeField(name='timestamp',                     
auto_now_add=True,)
...
class Assets(models.Model):
id = models.AutoField(db_column='Id', primary_key=True)
assettag = models.CharField(db_column='AssetTag', unique=True, max_length=10)
assettype = models.CharField(db_column='AssetType', max_length=150)
...
class Meta:
managed = False
db_table = 'Assets'
ordering = ['assettag']
def __str__(self):
return f"{self.assettag}"
def __unicode__(self):
return f"{self.assettag}"

为此,我创建了以下表单和表单集:

class ItemDeleteForm(forms.ModelForm):
asset = forms.CharField(required=True,
help_text= "Item asset tag",
max_length=16,
label="AssetTag",
disabled=True,
)
delete = forms.BooleanField(required=False,
label="Delete",
help_text='Check this box to delete the corresponding item',
)
class Meta:
model = Item
fields = ['asset']
ItemDeleteMultiple = forms.modelformset_factory(model=Item,
form=ItemDeleteForm,
extra=0,
)

由视图管理:

class DeleteMultipleView(generic.FormView):
template_name = '*some html file*'
form_class = ItemDeleteMultiple
success_url = reverse_lazy('*app_name:url_name*')
def form_valid(self, form):
return super().form_valid(form)

并在模板中呈现:

{% extends "pages/base.html" %}
{% block title %}
<title>Delete Multiple</title>
{% endblock %}
{% block content %}
<h1>Delete Multiple Items</h1>
<br>
<form class="ManualForm" action ="." method="POST"> {% csrf_token %}
{{ form.management_form }}
<table border="2">
<tr><th colspan="3" scope="row">Select Items to Delete</th></tr>
{% for item_form in form %}
<tr>
<td><label for="{{ item_form.asset.id_for_label }}">AssetTag {{forloop.counter}}:</label>
{% if item_form.non_field_errors %}
{{ item_form.non_field_errors }}
{% endif %}
{% if item_form.asset.errors %}
{{item_form.asset.errors}}
{% endif %}
</td>
<td>{{item_form.asset}}</td>
<td>{{item_form.delete}}
{% if item_form.delete.errors %}
{{item_form.delete.errors}}
{% endif %}
</td>
</tr>
{% endfor %}
</table>
<br>
<input class = "btn btn-success" type="submit" value="Delete Selected" />
<a href="{% url 'inventory:index' %}" class="btn btn-secondary">Cancel</a>
</form>
<form class="AutoForm" action ="." method="POST"> {% csrf_token %}
{{form.as_table}}
<input class = "btn btn-success" type="submit" value="Delete Selected" />
<a href="{% url 'inventory:index' %}" class="btn btn-secondary">Cancel</a>
</form>
{% endblock %}

当我提交自动表单时,一切都很棒。这需要我app_name:url_name,但是如果我总结手动表单,我不会被重定向。它将简单地清除所有数据并使用空字段重新加载表单页面。

AutoForm 的 HTTP POST 响应状态代码为 302,而 ManualForm 的 HTTP POST 响应状态代码为 200。

我不明白模板如何影响 url 重定向的行为。我在手动呈现表单集时做错了什么?

似乎添加:

{% for field in item_form.hidden_fields %}
{{field}}
{% endfor %}

{% for item_form in form %}下将解决问题。

我从文档中不太明白:

循环访问隐藏字段和可见字段

如果您在模板中手动布局表单,而不是 依靠 Django 的默认表单布局,你可能想要对待<输入类型>字段与非隐藏字段不同。为 例如,因为隐藏字段不显示任何内容,因此放置错误 字段"旁边"的消息可能会给您的用户带来混淆 - 因此 应以不同的方式处理这些字段的错误。

我只是认为这是关于错误的,所以我不在乎。但是它说的关于形式的第一件事是这样的:

例如,Django 管理员的登录表单包含几个<输入>元素:用户名类型="文本"之一,用户名之一 type="password"作为密码,type="submit"之一作为密码 "登录"按钮。它还包含一些隐藏的文本字段, 用户看不到,Django 使用哪个来确定下一步该做什么。

它还告诉浏览器表单数据应发送到 URL 在<窗体中指定>的操作属性 -/admin/- 并且它 应使用该方法指定的 HTTP 机制发送 属性 - 帖子。

也许它会帮助其他人。

最新更新