[Django高级之forms组件]
forms组件之校验字段
第一步:定义一个类,继承forms.Form
第二步:在类中写字段,要校验的字段,字段属性就是校验规则
第三步:实例化得到一个Form对象,把要校验的数据传入
第四步:调用 对象.is_valid()校验,校验通过就是True
可以判断是否符合定义的字段条件
第五步:校验通过有 对象.cleaned_data
获取符合校验规则的数据
第六步:校验不通过 对象.errors
获取不符合校验的字段、以及错误信息
前戏
写一个注册页面获取用户的用户名和密码
发送到后端之后在后端完成对用户名和密码的数据校验
1.用户名里面不能含有JPZ
2.密码不能为空
将提示信息渲染到前端页面
1.前端页面标签书写
2.前端页面信息展示
3.后端数据校验
forms组件可以一条龙服务 帮你完成上面的三件事情
1.渲染标签
2.校验数据
3.展示信息
img
forms组件校验数据
1、对象 .is_valid()
2、对象 .cleaned_data
3、对象 .errors
forms代码书写
from django import forms
class MyForm(forms.Form):
# username字段最少不能少于3位 最多不能超过8位
username = forms.CharField(max_length=8,min_length=3)
# password字段最大值不能超过699
password = forms.IntegerField(max_value=699)
# email字段必须符合邮箱格式
email = forms.EmailField()
校验数据
from app01 import views
1.类加括号 传入字典即可
form_obj = views.MyForm({'username':'jason','password':'123','email':'嘿嘿嘿'})
2.判断数据是否合法(只有全部合法结果才为True)
form_obj.is_valid()
False
3.查看所有合法的数据
form_obj.cleaned_data
{'username': 'jason', 'password': 123}
4.查看所有不合法的数据及原因
form_obj.errors
{'email': ['Enter a valid email address.']}
“”"
校验数据可以多传 但是不能少传(默认必填)
“”"
校验数据可以多传 但是不能少传(默认必填)
forms组件渲染标签
def register(request):
if request.method == ‘GET’:
# GET请求没有数据,需要生成一个空form对象
# 这个form跟下面没有关系,是get请求过来的得到一个空form
register_form = RegisterFrom()
# 传到前端页面后,通过form进行渲染
return render(request, ‘register.html’, {‘form’: register_form})
else:
register_form = RegisterFrom(request.POST)
if register_form.is_valid():
print('效验通过')
print(register_form.cleaned_data)
register_form.cleaned_data.pop('re_password')
models.User.objects.create(**register_form.cleaned_data)
else:
print('效验不通过')
print(register_form.errors)
return render(request,'register.html')
渲染方式一
可扩展性强,但是需要书写的代码太多,一般情况下不用
通过form自动渲染一
用户名 {{ form.name }}
密码 {{ form.password }}
确认密码 {{ form.re_password }}
邮箱 {{ form.email }}
渲染方式二 推荐使用,代码书写简单,并且可扩展性强通过form自动渲染二(基本用这种)
{% for item in form %}{{ item.label }}{{ item }}
{% endfor %} {{ error }} 渲染方式三 代码书写极少,封装程度太高,不便于后续的扩展,一般情况下只在本地测试使用