在Django的視圖中使用form對(duì)象的方法
在學(xué)習(xí)了關(guān)于Form類的基本知識(shí)后,你會(huì)看到我們?nèi)绾伟阉玫揭晥D中,取代contact()代碼中不整齊的部分。 一下示例說明了我們?nèi)绾斡胒orms框架重寫contact():
# views.py from django.shortcuts import render_to_response from mysite.contact.forms import ContactForm def contact(request): if request.method == 'POST': form = ContactForm(request.POST) if form.is_valid(): cd = form.cleaned_data send_mail( cd['subject'], cd['message'], cd.get('email', 'noreply@example.com'), ['siteowner@example.com'], ) return HttpResponseRedirect('/contact/thanks/') else: form = ContactForm() return render_to_response('contact_form.html', {'form': form}) # contact_form.html <html> <head> <title>Contact us</title> </head> <body> <h1>Contact us</h1> {% if form.errors %} <p style="color: red;"> Please correct the error{{ form.errors|pluralize }} below. </p> {% endif %} <form action="" method="post"> <table> {{ form.as_table }} </table> <input type="submit" value="Submit"> </form> </body> </html>
看看,我們能移除這么多不整齊的代碼! Django的forms框架處理HTML顯示、數(shù)據(jù)校驗(yàn)、數(shù)據(jù)清理和表單錯(cuò)誤重現(xiàn)。
嘗試在本地運(yùn)行。 裝載表單,先留空所有字段提交空表單;繼而填寫一個(gè)錯(cuò)誤的郵箱地址再嘗試提交表單;最后再用正確數(shù)據(jù)提交表單。 (根據(jù)服務(wù)器的設(shè)置,當(dāng)send_mail()被調(diào)用時(shí),你將得到一個(gè)錯(cuò)誤提示。而這是另一個(gè)問題。)
改變字段顯示
你可能首先注意到:當(dāng)你在本地顯示這個(gè)表單的時(shí),message字段被顯示成`` input type=”text”`` ,而它應(yīng)該被顯示成<`` textarea`` >。我們可以通過設(shè)置* widget* 來修改它:
from django import forms class ContactForm(forms.Form): subject = forms.CharField() email = forms.EmailField(required=False) message = forms.CharField(**widget=forms.Textarea** )
forms框架把每一個(gè)字段的顯示邏輯分離到一組部件(widget)中。 每一個(gè)字段類型都擁有一個(gè)默認(rèn)的部件,我們也可以容易地替換掉默認(rèn)的部件,或者提供一個(gè)自定義的部件。
考慮一下Field類表現(xiàn)* 校驗(yàn)邏輯* ,而部件表現(xiàn)* 顯示邏輯* 。
設(shè)置最大長度
一個(gè)最經(jīng)常使用的校驗(yàn)要求是檢查字段長度。 另外,我們應(yīng)該改進(jìn)ContactForm,使subject限制在100個(gè)字符以內(nèi)。 為此,僅需為CharField提供max_length參數(shù),像這樣:
from django import forms class ContactForm(forms.Form): subject = forms.CharField(**max_length=100** ) email = forms.EmailField(required=False) message = forms.CharField(widget=forms.Textarea)
選項(xiàng)min_length參數(shù)同樣可用。
設(shè)置初始值
讓我們?cè)俑倪M(jìn)一下這個(gè)表單:為字subject段添加* 初始值* : "I love your site!" (一點(diǎn)建議,但沒壞處。)為此,我們可以在創(chuàng)建Form實(shí)體時(shí),使用initial參數(shù):
def contact(request): if request.method == 'POST': form = ContactForm(request.POST) if form.is_valid(): cd = form.cleaned_data send_mail( cd['subject'], cd['message'], cd.get('email', `'noreply@example.com`_'), [`'siteowner@example.com`_'], ) return HttpResponseRedirect('/contact/thanks/') else: form = ContactForm( **initial={'subject': 'I love your site!'}** ) return render_to_response('contact_form.html', {'form': form})
現(xiàn)在,subject字段將被那個(gè)句子填充。
請(qǐng)注意,傳入* 初始值* 數(shù)據(jù)和傳入數(shù)據(jù)以* 綁定* 表單是有區(qū)別的。 最大的區(qū)別是,如果僅傳入* 初始值* 數(shù)據(jù),表單是unbound的,那意味著它沒有錯(cuò)誤消息。
自定義校驗(yàn)規(guī)則
假設(shè)我們已經(jīng)發(fā)布了反饋頁面了,email已經(jīng)開始源源不斷地涌入了。 這里有一個(gè)問題: 一些提交的消息只有一兩個(gè)字,我們無法得知詳細(xì)的信息。 所以我們決定增加一條新的校驗(yàn): 來點(diǎn)專業(yè)精神,最起碼寫四個(gè)字,拜托。
我們有很多的方法把我們的自定義校驗(yàn)掛在Django的form上。 如果我們的規(guī)則會(huì)被一次又一次的使用,我們可以創(chuàng)建一個(gè)自定義的字段類型。 大多數(shù)的自定義校驗(yàn)都是一次性的,可以直接綁定到form類.
我們希望`` message`` 字段有一個(gè)額外的校驗(yàn),我們?cè)黾右粋€(gè)`` clean_message()`` 方法到`` Form`` 類:
from django import forms class ContactForm(forms.Form): subject = forms.CharField(max_length=100) email = forms.EmailField(required=False) message = forms.CharField(widget=forms.Textarea) def clean_message(self): message = self.cleaned_data['message'] num_words = len(message.split()) if num_words < 4: raise forms.ValidationError("Not enough words!") return message
Django的form系統(tǒng)自動(dòng)尋找匹配的函數(shù)方法,該方法名稱以clean_開頭,并以字段名稱結(jié)束。 如果有這樣的方法,它將在校驗(yàn)時(shí)被調(diào)用。
特別地,clean_message()方法將在指定字段的默認(rèn)校驗(yàn)邏輯執(zhí)行* 之后* 被調(diào)用。(本例中,在必填CharField這個(gè)校驗(yàn)邏輯之后。)因?yàn)樽侄螖?shù)據(jù)已經(jīng)被部分處理,所以它被從self.cleaned_data中提取出來了。同樣,我們不必?fù)?dān)心數(shù)據(jù)是否為空,因?yàn)樗呀?jīng)被校驗(yàn)過了。
我們簡單地使用了len()和split()的組合來計(jì)算單詞的數(shù)量。 如果用戶輸入字?jǐn)?shù)不足,我們拋出一個(gè)forms.ValidationError型異常。這個(gè)異常的描述會(huì)被作為錯(cuò)誤列表中的一項(xiàng)顯示給用戶。
在函數(shù)的末尾顯式地返回字段的值非常重要。 我們可以在我們自定義的校驗(yàn)方法中修改它的值(或者把它轉(zhuǎn)換成另一種Python類型)。 如果我們忘記了這一步,None值就會(huì)返回,原始的數(shù)據(jù)就丟失掉了。
指定標(biāo)簽
HTML表單中自動(dòng)生成的標(biāo)簽?zāi)J(rèn)是按照規(guī)則生成的:用空格代替下劃線,首字母大寫。如email的標(biāo)簽是"Email" 。(好像在哪聽到過? 是的,同樣的邏輯被用于模塊(model)中字段的verbose_name值。 我們?cè)诘谖逭抡劦竭^。)
像在模塊中做過的那樣,我們同樣可以自定義字段的標(biāo)簽。 僅需使用label,像這樣:
class ContactForm(forms.Form): subject = forms.CharField(max_length=100) email = forms.EmailField(required=False, **label='Your e-mail address'** ) message = forms.CharField(widget=forms.Textarea)
- Django ModelForm組件使用方法詳解
- 基于Django的ModelForm組件(詳解)
- django中forms組件的使用與注意
- Django中的forms組件實(shí)例詳解
- Django forms組件的使用教程
- 在Django的form中使用CSS進(jìn)行設(shè)計(jì)的方法
- 詳解Django中的form庫的使用
- Python中使用django form表單驗(yàn)證的方法
- 利用Django提供的ModelForm增刪改數(shù)據(jù)的方法
- Django中Forms的使用代碼解析
- Django Form 實(shí)時(shí)從數(shù)據(jù)庫中獲取數(shù)據(jù)的操作方法
- Python Web框架之Django框架Form組件用法詳解
相關(guān)文章
Python Pandas實(shí)現(xiàn)DataFrame合并的圖文教程
我們?cè)谑褂胮andas處理數(shù)據(jù)的時(shí)候,往往會(huì)需要合并兩個(gè)或者多個(gè)DataFrame的操作,下面這篇文章主要給大家介紹了關(guān)于Pandas實(shí)現(xiàn)DataFrame合并的相關(guān)資料,需要的朋友可以參考下2022-07-07Python學(xué)習(xí)筆記之json模塊和pickle模塊
json和pickle模塊是將數(shù)據(jù)進(jìn)行序列化處理,并進(jìn)行網(wǎng)絡(luò)傳輸或存入硬盤,下面這篇文章主要給大家介紹了關(guān)于Python學(xué)習(xí)筆記之json模塊和pickle模塊的相關(guān)資料,文中通過實(shí)例代碼介紹的非常詳細(xì),需要的朋友可以參考下2023-05-05pycharm中使用anaconda部署python環(huán)境的方法步驟
這篇文章主要介紹了pycharm中使用anaconda部署python環(huán)境的方法步驟,小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧2018-12-12Django Model中字段(field)的各種選項(xiàng)說明
這篇文章主要介紹了Django Model中字段(field)的各種選項(xiàng)說明,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過來看看吧2020-05-05