django学习~forms

时间:2022-07-19 15:15:04

一 简介 今天咱们来聊聊 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如果不可能则会引发

clean_<fieldname>()在表单子类上调用该方法, 是一个Python对象,而不是表单中提交的原始字符串 cleaned_data

3 表单子类的clean()方法

1 可以执行需要访问多个表单字段的验证。您可以在此处进行检查,例如“如果A提供了字段,则字段B必须包含有效的电子邮件地址”。如果愿意,这个方法可以返回一个完全不同的字典,它将被用作cleaned_data

2 由于字段验证方法已在clean()调用时运行,因此您还可以访问表单的errors属性,该属性包含清除单个字段引起的所有错误。

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 一般会打印在页面的顶端