表单验证器
表单验证器是检查整个表单数据是否符合特定要求的函数。表单验证器通常用于检查表单字段之间的关系或对表单数据进行全局验证。我们可以通过在表单类中定义一个clean
方法来编写表单验证器。
例如,以下是一个表单类,它包含两个密码字段,并确保它们的值匹配:
代码语言:javascript复制from django import forms
class ContactForm(forms.Form):
name = forms.CharField(label='Your Name', max_length=100)
email = forms.EmailField(label='Your Email')
message = forms.CharField(widget=forms.Textarea)
def clean_message(self):
message = self.cleaned_data.get('message')
if len(message.strip()) < 5:
raise forms.ValidationError("Message is too short.")
return message
在这个示例中,我们定义了一个名为ContactForm
的表单,它包含三个字段:name
,email
和message
。name
和email
字段都是字符字段,而message
字段是一个多行文本字段。
我们还定义了一个名为clean_message
的表单验证方法。在这个方法中,我们首先获取表单的message
字段,并将其清除左右两侧的空格。然后,我们检查该字段是否少于5个字符,如果是,我们将引发一个ValidationError
异常。否则,我们将返回清理后的message
字段。
在视图中,我们可以通过以下方式处理提交的表单:
代码语言:javascript复制from django.shortcuts import render
from .forms import ContactForm
def contact(request):
if request.method == 'POST':
form = ContactForm(request.POST)
if form.is_valid():
# 处理表单数据
name = form.cleaned_data['name']
email = form.cleaned_data['email']
message = form.cleaned_data['message']
# ...
else:
form = ContactForm()
return render(request, 'contact.html', {'form': form})
在这个示例中,我们首先检查请求方法是否为POST。如果是,我们将实例化一个ContactForm
对象,并将请求数据传递给它。然后,我们检查表单是否有效。如果有效,我们将使用cleaned_data
字典来获取验证通过的表单数据,并进行进一步处理。否则,我们将返回一个带有错误表单的ContactForm
对象。
在模板中,我们可以使用以下代码来呈现表单:
代码语言:javascript复制<form method="post">
{% csrf_token %}
{{ form.as_p }}
<button type="submit">Submit</button>
</form>
在这个示例中,我们使用{{ form.as_p }}
模板标记来呈现表单。这将以段落形式呈现表单字段。我们还包含了一个名为csrf_token
的标记,它将在处理POST请求时使用,以防止跨站点请求伪造攻击。