urls.py文件內容
from app01 import views urlpatterns = [ path('fm/', views.fm), ]
views.py文件內容
#表單驗證 #引入forms模塊 from django import forms #創建 class FM(forms.Form): #變量名字必須要跟form表單裏的名字一一對應 user = forms.CharField(error_messages={'required': '用戶不能爲空'}) #ChharField表示傳入的得是字符串 pwd = forms.CharField( max_length=12,#最大字符串爲12個 min_length=6, #最小字符串爲6個 error_messages={'required': '密碼不能爲空','min_length':'最小字符爲6個','max_length':'最大字符爲12個'} ) #ChharField表示傳入的得是字符串 email = forms.EmailField(error_messages={'required': '郵箱不能爲空','invalid':'郵箱地址不正確'}) #EmailField表示傳入的得是郵箱格式 def fm(request): if request.method == "GET": #不用傳入參數創建FM對象,對象名字obj必須跟下面的對象名字obj一樣, obj = FM() #如果把obj這樣傳入fm.html裏之後,那麼fm.html裏的內容就可以用以下方式寫:直接用{{ obj.user }}、{{ obj.pwd }}、{{ obj.email }}生成html元素 #並且保留上一次提交的數據 """ <form action="/app01/fm/" method="post"> {% csrf_token %} <p>{{ obj.user }}{{ obj.errors.user.0 }}</p> <p>{{ obj.pwd }}{{ obj.errors.pwd.0 }}</p> <p>{{ obj.email }}{{ obj.errors.pwd.0 }}</p> <input type="submit" value="提交"> </form>""" return render(request,'fm.html',{'obj':obj}) elif request.method == 'POST': #創建驗證對象,並且把request.POST(提交的POST裏面所有的數據)傳進去 obj = FM(request.POST) #obj.is_valid()會產出一個返回值:是否成功 布爾類型 r1 = obj.is_valid() print(r1) if r1: #驗證通過之後返回正確信息的一個字典obj.cleaned_data,這是個字典 #此處如果是註冊功能的話,就可以把註冊信息的字典寫入數據庫 print(obj.cleaned_data) else: #驗證不通過之後返回一個所有的錯誤信息:obj.errors,是一大串字符串一個包含user、pwd、email錯誤信息的html格式的ul標籤 print(obj.errors) #獲取user的第一個錯誤信息 # print(obj.errors['user'][0]) #會把字符串轉換成字典形式 print(obj.errors.as_json()) """錯誤信息裏的錯誤提示信息可以改成自定義中文的,後面加參數 class FM(forms.Form): #變量名字必須要跟form表單裏的名字一一對應 user = forms.CharField(error_messages={'required': '用戶不能爲空'}) #ChharField表示傳入的得是字符串 pwd = forms.CharField(error_messages={'required': '密碼不能爲空'}) #ChharField表示傳入的得是字符串 email = forms.EmailField(error_messages={'required': '郵箱不能爲空','invalid':'郵箱地址不正確'}) #EmailField表示傳入的得是郵箱格式 """ #把obj對象以參數形式傳入到fm.html裏進行渲染 return render(request,'fm.html',{'obj':obj}) return render(request, 'fm.html')
fm.html文件內容
<!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8"> <title>Title</title> </head> <body> <form action="/app01/fm/" method="post"> {% csrf_token %} <p><input type="text" name="user">{{ obj.errors.user.0 }}</p> <p><input type="password" name="pwd">{{ obj.errors.pwd.0 }}</p> <p><input type="text" name="email">{{ obj.errors.pwd.0 }}</p> <input type="submit" value="提交"> </form> </body> </html>