一 简介 今天咱们来聊聊 django强大的表单功能
二 Froms作用
1 自动生成HTML表单元素
2 检查表单数据的合法性
3 如果验证错误,重新显示表单(数据不会重置)
4 数据类型转换(字符类型的数据转换成相应的Python类型)
三 创建
1 forms.py
from django import forms //导入模块
class Form1(forms.Form):
user = forms.CharField()
pwd = forms.CharField()
class Meta:
db_table='info'
verbose_name='info'
verbose_name_plural='info'
def clean(self):
user1=self.cleaned_data["user"]
password=self.cleaned_data["pwd"]
user_model = list(userinfo.objects.all().values_list('name'))
for i in user_model:
if user1 in i:
raise ValidationError("the value is not only")
return self.cleaned_data
userinfo.objects.create(name=user1,password=password)
表单验证 -> forms
通用属性
required 属性 1 默认是非空,必须要填写值,设置required=False 可以不添值提交
label 属性 1 相当于html中的label显示输出
initial 属性 1 设置框内显示的默认初始值 2 在提交到后台时必须重新赋予变量才能进行二次处理 eg initial=datetime.date.toda
Widget 属性 1 渲染 eg widget=forms.Textarea
help_text 属性 1 帮助
error_messages 属性 1 覆盖错误 自定义错误信息 error_messages={'required': 'Please enter your name'} 2 如果标注此属性,则会代替原有报警信息
字段属性
charfield 错误键信息 required,max_length,min_length
DateField 错误键信息 required,invalid
DateTimeField 错误键信息 required,invalid
EmailField 错误键信息 required,invalid
FileField 错误键信息 required,invalid,missing,empty, max_length
IntegerField 错误键信息 required,invalid,max_value, min_value
2 views.py
from myapp.forms import *
关键函数
form.is_valid() //判断整体表单的有效性
form.cleaned_data //表单的对象集合,取值填写key即可
3 template
<form action="." method="post">
{% for field in form %}
{% csrf_token %}
<div>
{{ field.label_tag }}:{{ field }}
{{ field.errors }}
</div>
{% endfor %}
label_tag label标签
field:字段
error:当出现问题时提示错误
csrf_token:防止csrf跨站攻击
四 总结
1 form的本质就是形成自定义表单+一定的验证机制功能
2 表单方法
form.is_valid():验证表单数据是否合法
form.errors:表单的错误以字典形式返回(如果有多个错误,可以循环这个字典,然后传给前端)
form.clean_data:获取表单数据
form.as_p:将表单渲染成P标签
五 验证机制
1 to_python()
方法Field
是每次验证的第一步。它将值强制转换为正确的数据类型,ValidationError
如果不可能则会引发
2 clean_<fieldname>()
在表单子类上调用该方法, 是一个Python对象,而不是表单中提交的原始字符串 cleaned_data
3 表单子类的clean()
方法
1 可以执行需要访问多个表单字段的验证。您可以在此处进行检查,例如“如果A
提供了字段,则字段B
必须包含有效的电子邮件地址”。如果愿意,这个方法可以返回一个完全不同的字典,它将被用作cleaned_data
。
2 由于字段验证方法已在clean()
调用时运行,因此您还可以访问表单的errors
属性,该属性包含清除单个字段引起的所有错误。
3 Form.clean()
覆盖引发的任何错误都不会与任何字段相关联。它们进入一个特殊的“字段”(称为__all__
)
4 针对表单的每个字段重复执行以上值
5 表单子类add_error()方法
add_error('key',ValidationError('msg')/msg') 推荐绑定ValidationError 实例
五 自定义clean验证
方式
class a:
def clean(self)
self.add_error('user',ValidationError('aaaaa'))// 绑定
return self.cleaned_data //返回cleaned_data
template打印
forms.error 一般会打印在页面的顶端