【資料圖】

表單驗證器

表單驗證器是檢查整個表單數據是否符合特定要求的函數。表單驗證器通常用于檢查表單字段之間的關系或對表單數據進行全局驗證。我們可以通過在表單類中定義一個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的表單,它包含三個字段:name,emailmessage。nameemail字段都是字符字段,而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請求時使用,以防止跨站點請求偽造攻擊。

標簽: