(资料图)

表单验证器

表单验证器是检查整个表单数据是否符合特定要求的函数。表单验证器通常用于检查表单字段之间的关系或对表单数据进行全局验证。我们可以通过在表单类中定义一个clean方法来编写表单验证器。

例如,以下是一个表单类,它包含两个密码字段,并确保它们的值匹配:

from django import formsclass 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的表单,它包含三个字段:nameemailmessagenameemail字段都是字符字段,而message字段是一个多行文本字段。

我们还定义了一个名为clean_message的表单验证方法。在这个方法中,我们首先获取表单的message字段,并将其清除左右两侧的空格。然后,我们检查该字段是否少于5个字符,如果是,我们将引发一个ValidationError异常。否则,我们将返回清理后的message字段。

在视图中,我们可以通过以下方式处理提交的表单:

from django.shortcuts import renderfrom .forms import ContactFormdef 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对象。

在模板中,我们可以使用以下代码来呈现表单:

{% csrf_token %} {{ form.as_p }}

在这个示例中,我们使用{{ form.as_p }}模板标记来呈现表单。这将以段落形式呈现表单字段。我们还包含了一个名为csrf_token的标记,它将在处理POST请求时使用,以防止跨站点请求伪造攻击。

关键词: