【資料圖】
表單驗(yàn)證器是檢查整個(gè)表單數(shù)據(jù)是否符合特定要求的函數(shù)。表單驗(yàn)證器通常用于檢查表單字段之間的關(guān)系或?qū)Ρ韱螖?shù)據(jù)進(jìn)行全局驗(yàn)證。我們可以通過在表單類中定義一個(gè)clean
方法來編寫表單驗(yàn)證器。
例如,以下是一個(gè)表單類,它包含兩個(gè)密碼字段,并確保它們的值匹配:
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
在這個(gè)示例中,我們定義了一個(gè)名為ContactForm
的表單,它包含三個(gè)字段:name
,email
和message
。name
和email
字段都是字符字段,而message
字段是一個(gè)多行文本字段。
我們還定義了一個(gè)名為clean_message
的表單驗(yàn)證方法。在這個(gè)方法中,我們首先獲取表單的message
字段,并將其清除左右兩側(cè)的空格。然后,我們檢查該字段是否少于5個(gè)字符,如果是,我們將引發(fā)一個(gè)ValidationError
異常。否則,我們將返回清理后的message
字段。
在視圖中,我們可以通過以下方式處理提交的表單:
from django.shortcuts import renderfrom .forms import ContactFormdef contact(request): if request.method == "POST": form = ContactForm(request.POST) if form.is_valid(): # 處理表單數(shù)據(jù) 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})
在這個(gè)示例中,我們首先檢查請(qǐng)求方法是否為POST。如果是,我們將實(shí)例化一個(gè)ContactForm
對(duì)象,并將請(qǐng)求數(shù)據(jù)傳遞給它。然后,我們檢查表單是否有效。如果有效,我們將使用cleaned_data
字典來獲取驗(yàn)證通過的表單數(shù)據(jù),并進(jìn)行進(jìn)一步處理。否則,我們將返回一個(gè)帶有錯(cuò)誤表單的ContactForm
對(duì)象。
在模板中,我們可以使用以下代碼來呈現(xiàn)表單:
在這個(gè)示例中,我們使用{{ form.as_p }}
模板標(biāo)記來呈現(xiàn)表單。這將以段落形式呈現(xiàn)表單字段。我們還包含了一個(gè)名為csrf_token
的標(biāo)記,它將在處理POST請(qǐng)求時(shí)使用,以防止跨站點(diǎn)請(qǐng)求偽造攻擊。
[責(zé)任編輯:linlin]
標(biāo)簽: