詳解Django中的form庫的使用
Django帶有一個(gè)form庫,稱為django.forms,這個(gè)庫可以處理我們本章所提到的包括HTML表單顯示以及驗(yàn)證。 接下來我們來深入了解一下form庫,并使用她來重寫contact表單應(yīng)用。
Django的newforms庫
在Django社區(qū)上會(huì)經(jīng)??吹絛jango.newforms這個(gè)詞語。當(dāng)人們討論django.newforms,其實(shí)就是我們本章里面介紹的django.forms。
改名其實(shí)有歷史原因的。 當(dāng)Django一次向公眾發(fā)行時(shí),它有一個(gè)復(fù)雜難懂的表單系統(tǒng):django.forms。后來它被完全重寫了,新的版本改叫作:django.newforms,這樣人們還可以通過名稱,使用舊版本。 當(dāng)Django 1.0發(fā)布時(shí),舊版本django.forms就不再使用了,而django.newforms也終于可以名正言順的叫做:django.forms。
表單框架最主要的用法是,為每一個(gè)將要處理的HTML的`` <Form>`` 定義一個(gè)Form類。 在這個(gè)例子中,我們只有一個(gè)`` <Form>`` ,因此我們只需定義一個(gè)Form類。 這個(gè)類可以存在于任何地方,甚至直接寫在`` views.py`` 文件里也行,但是社區(qū)的慣例是把Form類都放到一個(gè)文件中:forms.py。在存放`` views.py`` 的目錄中,創(chuàng)建這個(gè)文件,然后輸入:
from django import forms class ContactForm(forms.Form): subject = forms.CharField() email = forms.EmailField(required=False) message = forms.CharField()
這看上去簡單易懂,并且很像在模塊中使用的語法。 表單中的每一個(gè)字段(域)作為Form類的屬性,被展現(xiàn)成Field類。這里只用到CharField和EmailField類型。 每一個(gè)字段都默認(rèn)是必填。要使email成為可選項(xiàng),我們需要指定required=False。
讓我們鉆研到Python解釋器里面看看這個(gè)類做了些什么。 它做的第一件事是將自己顯示成HTML:
>>> from contact.forms import ContactForm >>> f = ContactForm() >>> print f <tr><th><label for="id_subject">Subject:</label></th><td><input type="text" name="subject" id="id_subject" /></td></tr> <tr><th><label for="id_email">Email:</label></th><td><input type="text" name="email" id="id_email" /></td></tr> <tr><th><label for="id_message">Message:</label></th><td><input type="text" name="message" id="id_message" /></td></tr>
為了便于訪問,Django用`` <label>`` 標(biāo)志,為每一個(gè)字段添加了標(biāo)簽。 這個(gè)做法使默認(rèn)行為盡可能合適。
默認(rèn)輸出按照HTML的<`` table`` >格式,另外有一些其它格式的輸出:
>>> print f.as_ul() <li><label for="id_subject">Subject:</label> <input type="text" name="subject" id="id_subject" /></li> <li><label for="id_email">Email:</label> <input type="text" name="email" id="id_email" /></li> <li><label for="id_message">Message:</label> <input type="text" name="message" id="id_message" /></li> >>> print f.as_p() <p><label for="id_subject">Subject:</label> <input type="text" name="subject" id="id_subject" /></p> <p><label for="id_email">Email:</label> <input type="text" name="email" id="id_email" /></p> <p><label for="id_message">Message:</label> <input type="text" name="message" id="id_message" /></p>
請注意,標(biāo)簽<table>、<ul>、<form>的開閉合標(biāo)記沒有包含于輸出當(dāng)中,這樣你就可以添加額外的行或者自定義格式。
這些類方法只是一般情況下用于快捷顯示完整表單的方法。 你同樣可以用HTML顯示個(gè)別字段:
>>> print f['subject'] <input type="text" name="subject" id="id_subject" /> >>> print f['message'] <input type="text" name="message" id="id_message" />
Form對象做的第二件事是校驗(yàn)數(shù)據(jù)。 為了校驗(yàn)數(shù)據(jù),我們創(chuàng)建一個(gè)新的對Form象,并且傳入一個(gè)與定義匹配的字典類型數(shù)據(jù):
>>> f = ContactForm({'subject': 'Hello', 'email': 'adrian@example.com', 'message': 'Nice site!'})
一旦你對一個(gè)Form實(shí)體賦值,你就得到了一個(gè)綁定form:
>>> f.is_bound True
調(diào)用任何綁定form的is_valid()方法,就可以知道它的數(shù)據(jù)是否合法。 我們已經(jīng)為每個(gè)字段傳入了值,因此整個(gè)Form是合法的:
>>> f.is_valid() True
如果我們不傳入email值,它依然是合法的。因?yàn)槲覀冎付ㄟ@個(gè)字段的屬性required=False:
>>> f = ContactForm({'subject': 'Hello', 'message': 'Nice site!'}) >>> f.is_valid() True
但是,如果留空subject或message,整個(gè)Form就不再合法了:
>>> f = ContactForm({'subject': 'Hello'}) >>> f.is_valid() False >>> f = ContactForm({'subject': 'Hello', 'message': ''}) >>> f.is_valid() False
你可以逐一查看每個(gè)字段的出錯(cuò)消息:
>>> f = ContactForm({'subject': 'Hello', 'message': ''}) >>> f['message'].errors [u'This field is required.'] >>> f['subject'].errors [] >>> f['email'].errors []
每一個(gè)邦定Form實(shí)體都有一個(gè)errors屬性,它為你提供了一個(gè)字段與錯(cuò)誤消息相映射的字典表。
>>> f = ContactForm({'subject': 'Hello', 'message': ''}) >>> f.errors {'message': [u'This field is required.']}
最終,如果一個(gè)Form實(shí)體的數(shù)據(jù)是合法的,它就會(huì)有一個(gè)可用的cleaned_data屬性。 這是一個(gè)包含干凈的提交數(shù)據(jù)的字典。 Django的form框架不但校驗(yàn)數(shù)據(jù),它還會(huì)把它們轉(zhuǎn)換成相應(yīng)的Python類型數(shù)據(jù),這叫做清理數(shù)據(jù)。
>>> f = ContactForm({subject': Hello, email: adrian@example.com, message: Nice site!}) >>> f.is_valid() True >>> f.cleaned_data {message': uNice site!, email: uadrian@example.com, subject: uHello}
我們的contact form只涉及字符串類型,它們會(huì)被清理成Unicode對象。如果我們使用整數(shù)型或日期型,form框架會(huì)確保方法使用合適的Python整數(shù)型或datetime.date型對象。
- Django ModelForm組件使用方法詳解
- 基于Django的ModelForm組件(詳解)
- django中forms組件的使用與注意
- Django中的forms組件實(shí)例詳解
- Django forms組件的使用教程
- 在Django的form中使用CSS進(jìn)行設(shè)計(jì)的方法
- Python中使用django form表單驗(yàn)證的方法
- 在Django的視圖中使用form對象的方法
- 利用Django提供的ModelForm增刪改數(shù)據(jù)的方法
- Django中Forms的使用代碼解析
- Django Form 實(shí)時(shí)從數(shù)據(jù)庫中獲取數(shù)據(jù)的操作方法
- Python Web框架之Django框架Form組件用法詳解
相關(guān)文章
Python日期格式和字符串格式相互轉(zhuǎn)換的方法
這篇文章主要介紹了Python日期格式和字符串格式相互轉(zhuǎn)換的方法,本文給大家介紹的非常詳細(xì),具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2020-02-02python實(shí)現(xiàn)圖片,視頻人臉識(shí)別(opencv版)
這篇文章主要介紹了python實(shí)現(xiàn)圖像,視頻人臉識(shí)別(opencv版)的的相關(guān)資料,幫助大家更好的理解和學(xué)習(xí)python,感興趣的朋友可以了解下2020-11-11python實(shí)現(xiàn)大文本文件分割成多個(gè)小文件
這篇文章主要為大家詳細(xì)介紹了python實(shí)現(xiàn)大文本文件分割成多個(gè)小文件,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2021-04-04Python用正則表達(dá)式實(shí)現(xiàn)爬取古詩文網(wǎng)站信息
這篇文章主要給大家介紹了關(guān)于Python如何利用正則表達(dá)式爬取爬取古詩文網(wǎng)站信息,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2021-12-12