您好,登錄后才能下訂單哦!
小編給大家分享一下django處理表單的方法,希望大家閱讀完這篇文章后大所收獲,下面讓我們一起去探討吧!
使用表單
假設你想從表單接收用戶名數據,一般情況下,你需要在HTML中手動編寫一個如下的表單元素:
<form action="/your-name/" method="post"> <label for="your_name">Your name: </label> <input id="your_name" type="text" name="your_name" value="{{ current_name }}"> <input type="submit" value="OK"></form>
<form action="/your-name/" method="post">這一行定義了我們的發送目的地/your-name/和HTTP方法POST。form元素內部還定義了一個說明標簽<label>和一個發送按鈕‘submit’,以及最關鍵的接收用戶輸入的<input>元素。
一、編寫表單類
我們可以通過Django提供的Form類來自用生成上面的表單,不再需要手動在HTML中編寫。
首先,在你當前app內新建一個forms.py文件(這個套路是Django的慣用手法,就像views.py,models.py等等),然后輸入下面的內容:
from django import forms class NameForm(forms.Form): your_name = forms.CharField(label='Your name', max_length=100)
提前導入forms模塊所有的表單類都要繼承forms.Form類每個表單字段都有自己的字段類型比如CharField,它們分別對應一種HTML語言中的<form>元素中的表單元素。這一點和Django模型系統的設計非常相似。例子中的label用于設置說明標簽max_length限制最大長度為100。它同時起到兩個作用,一是在瀏覽器頁面限制用戶輸入不可超過100個字符,二是在后端服務器驗證用戶輸入的長度不可超過100。
每個Django表單的實例都有一個內置的is_valid()方法,用來驗證接收的數據是否合法。如果所有數據都合法,那么該方法將返回True,并將所有的表單數據轉存到它的一個叫做cleaned_data的屬性中,該屬性是以個字典類型數據。
當我們將上面的表單渲染成真正的HTML元素,其內容如下:
<label for="your_name">Your name: </label> <input id="your_name" type="text" name="your_name" maxlength="100" required />
二、視圖處理
需要在視圖中,實例化我們編寫好的表單類。
# views.py from django.shortcuts import render from django.http import HttpResponseRedirect from .forms import NameForm def get_name(request): # 如果form通過POST方法發送數據 if request.method == 'POST': # 接受request.POST參數構造form類的實例 form = NameForm(request.POST) # 驗證數據是否合法 if form.is_valid(): # 處理form.cleaned_data中的數據 # ... # 重定向到一個新的URL return HttpResponseRedirect('/thanks/') # 如果是通過GET方法請求數據,返回一個空的表單 else: form = NameForm() return render(request, 'name.html', {'form': form})
要點是:
對于GET方法請求頁面時,返回空的表單,讓用戶可以填入數據;
對于POST方法,接收表單數據,并驗證;
如果數據合法,按照正常業務邏輯繼續執行下去;
如果不合法,返回一個包含先前數據的表單給前端頁面,方便用戶修改。
通過表單的is_bound屬性可以獲知一個表單已經綁定了數據,還是一個空表。
三、模板處理
在Django的模板中,我們只需要按下面處理,就可以得到完整的HTML頁面:
<form action="/your-name/" method="post"> {% csrf_token %} {{ form }} <input type="submit" value="Submit" /> </form>
要點:
<form>...</form>標簽要自己寫;
使用POST的方法時,必須添加{% csrf_token %}標簽,用于處理csrf安全機制;
{{ form }}代表Django為你生成其它所有的form標簽元素,也就是我們上面做的事情;
提交按鈕需要手動添加!
提示:默認情況下,Django支持HTML5的表單驗證功能,比如郵箱地址驗證、必填項目驗證等等。
看完了這篇文章,相信你對django處理表單的方法有了一定的了解,想了解更多相關知識,歡迎關注億速云行業資訊頻道,感謝各位的閱讀!
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。