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>