Infi-chu:

http://www.cnblogs.com/Infi-chu/

一、Django-forms作用

  • 前端和后端都要校验
  • 前端校验的目的:减少后端的压力
  • 用forms可以同时完成前端和后端的校验,而且可以减少代码量

二、forms的基本使用

1.定义数据的时候导入forms类

2.字段通过forms导入

views.py

from django.forms import Form
from django.forms import fields
class LoginForm(Form):
### 全部都是验证的规则
username = fields.CharField(
required=True, ### 不能为空
max_length=18, ### 最大的长度是18
min_length=6, ### 最小的长度是6
error_messages = { ### 对英文进行重写
"required" : "不能为空",
"max_length":"太长了",
"min_length":"太短了",
}
) pwd = fields.CharField()

3.方法中对于传参进行定义

views.py

def login(request):
if request.method == 'GET':
return render(request, "login.html")
else:
# username = request.POST.get('username')
# pwd = request.POST.get('pwd')
obj = LoginForm(request.POST) ## {"username":'xx', 'pwd':'xx'}
if obj.is_valid():
print(obj.cleaned_data) ## 对象
else:
print(obj.errors) ### 对象 __str__ return render(request, "login.html", {'obj':obj})

4.HTML中对于返回值进行渲染

login.html

# 渲染方式1
<form action="/login/" method="post">
username: <input type="text" name="username">{{ obj.errors.username.0 }}<br>
password: <input type="password" name="pwd">{{ obj.errors.pwd.0 }}<br>
<input type="submit" value="提交"><br>
</form> # 渲染方式2
#前提标题由forms组件进行
{{obj.username}} #对于字段的input框
{{obj.as_p }}#对象的所有字段
{{obj.errors.username }}#对象的错误信息

三、forms组件参数

1.Field

required=True,               是否允许为空
widget=None, HTML插件
label=None, 用于生成Label标签或显示内容
initial=None, 初始值
help_text='', 帮助信息(在标签旁边显示)
error_messages=None, 错误信息 {'required': '不能为空', 'invalid': '格式错误'}
validators=[], 自定义验证规则
localize=False, 是否支持本地化
disabled=False, 是否可以编辑
label_suffix=None Label内容后缀

2.CharField(Field)

max_length=None,             最大长度
min_length=None, 最小长度
strip=True 是否移除用户输入空白

3.IntegerField(IntegerField)

max_value=None,              最大值
min_value=None, 最小值

4.FloatField(IntegerField)

max_value=None,              最大值
min_value=None, 最小值

5.DecimalField(IntegerField)

max_value=None,              最大值
min_value=None, 最小值
max_digits=None, 总长度
decimal_places=None, 小数位长度

6.BaseTemporalField(Field)

input_formats=None          时间格式化

7.DateField(BaseTemporalField)

格式:2015-09-01

8.TimeField(BaseTemporalField)

格式:11:12

9.DateTimeField(BaseTemporalField)

格式:2015-09-01 11:12

10.DurationField(Field)

时间间隔:%d %H:%M:%S.%f

11.RegexField(CharField)

regex,                      自定制正则表达式
max_length=None, 最大长度
min_length=None, 最小长度
error_message=None, 忽略,错误信息使用 error_messages={'invalid': '...'}

12.EmailField(CharField)

13.FileField(Field)

allow_empty_file=False     是否允许空文件

14.ImageField(FileField)

  注:需要PIL模块,pip3 install Pillow
以上两个字典使用时,需要注意两点:
- form表单中 enctype="multipart/form-data"
- view函数中 obj = MyForm(request.POST, request.FILES)

15.URLField(Field)

16.BooleanField(Field)

17.NullBooleanField(BooleanField)

18.ChoiceField(Field)

choices=(),                选项,如:choices = ((0,'上海'),(1,'北京'),)
required=True, 是否必填
widget=None, 插件,默认select插件
label=None, Label内容
initial=None, 初始值
help_text='', 帮助提示

19.ModelChoiceField(ChoiceField)

   ...                        django.forms.models.ModelChoiceField
queryset, # 查询数据库中的数据
empty_label="---------", # 默认空显示内容
to_field_name=None, # HTML中value的值对应的字段
limit_choices_to=None # ModelForm中对queryset二次筛选

20.ModelMultipleChoiceField(ModelChoiceField)

 ...                        django.forms.models.ModelMultipleChoiceField

21.TypedChoiceField(ChoiceField)

coerce = lambda val: val   对选中的值进行一次转换
empty_value= '' 空值的默认值

22.MultipleChoiceField(ChoiceField)

23.TypedMultipleChoiceField(MultipleChoiceField)

coerce = lambda val: val   对选中的每一个值进行一次转换
empty_value= '' 空值的默认值

24.ComboField(Field)

fields=()                  使用多个验证,如下:即验证最大长度20,又验证邮箱格式
fields.ComboField(fields=[fields.CharField(max_length=20), fields.EmailField(),])

25.MultiValueField(Field)

PS: 抽象类,子类中可以实现聚合多个字典去匹配一个值,要配合MultiWidget使用

26.SplitDateTimeField(MultiValueField)

input_date_formats=None,   格式列表:['%Y--%m--%d', '%m%d/%Y', '%m/%d/%y']    input_time_formats=None    格式列表:['%H:%M:%S', '%H:%M:%S.%f', '%H:%M']

27.FilePathField(ChoiceField) 文件选项,目录下文件显示在页面中

path,                      文件夹路径
match=None, 正则匹配
recursive=False, 递归下面的文件夹
allow_files=True, 允许文件
allow_folders=False, 允许文件夹
required=True,
widget=None,
label=None,
initial=None,
help_text=''

28.GenericIPAddressField

protocol='both',           both,ipv4,ipv6支持的IP格式
unpack_ipv4=False 解析ipv4地址,如果是::ffff:192.0.2.1时候,可解析为192.0.2.1, PS:protocol必须为both才能启用

29.SlugField(CharField)

数字,字母,下划线,减号(连字符)

30.UUIDField(CharField)

uuid类型

eg、

from django.forms import Form
from django.forms import fields
from django.forms import Widget,PasswordInput
class LoginForm(Form):
username = fields.CharField(
required=True,
# label='用户名',
# initial=666,
# help_text='帮助信息',
# # disabled=True,
# label_suffix='--->',
max_length=18,
min_length=6,
error_messages={
'required' : '用户名不能为空',
'max_length': '用户名不能超过18',
'min_length': '用户名最小为6',
}
)
# password = fields.IntegerField(
# required=True,
# max_value=99999999,
# min_value=100000,
# error_messages={
# 'required' : '密码不能为空',
# 'invalid' : '格式不正确',
# 'min_value': '密码最少六位',
# 'max_value': '密码最多12位',
# },
# # widget=PasswordInput
# )
email = fields.EmailField()
def login(request):
if request.method == 'GET':
obj = LoginForm()
print(obj)
return render(request, 'login.html', {'obj':obj})
else:
# username = request.POST.get('username')
# print(username)
obj = LoginForm(request.POST)
if obj.is_valid():
print(obj.cleaned_data)
else:
errors = obj.errors
# <ul class="errorlist">
# <li>username
# <ul class="errorlist">
# <li>This field is required.</li>
# </ul>
# </li>
# </ul>
# print(type(errors))
# print(errors)
return render(request, 'login.html', {'obj' : obj})

Python Web(四)的更多相关文章

  1. Python Web 基础向(四) 浅谈数据层

    数据层一般会给人带来一些困扰,在于其定位不准确.聚合Model的工作也可以放在逻辑层做,但会导致逻辑层变重,经常出现大段晦涩代码.因此我的建议是保留Model聚合层,尽管会导致工作量的略微增加,但却可 ...

  2. python面试题四:Python web框架

    1 django.flask.tornado框架的比较? 2 什么是wsgi? WSGI的全称是Web Server Gateway Interface,翻译过来就是Web服务器网关接口.具体的来说, ...

  3. Redis的Python实践,以及四中常用应用场景详解——学习董伟明老师的《Python Web开发实践》

    首先,简单介绍:Redis是一个基于内存的键值对存储系统,常用作数据库.缓存和消息代理. 支持:字符串,字典,列表,集合,有序集合,位图(bitmaps),地理位置,HyperLogLog等多种数据结 ...

  4. tornado 学习笔记2 Python web主流框架

    2.1 Django 官方网址:https://www.djangoproject.com/ 简介:Django is a high-level Python Web framework that e ...

  5. [原]Python Web部署方式总结

    不要让服务器裸奔 学过PHP的都了解,php的正式环境部署非常简单,改几个文件就OK,用FastCgi方式也是分分钟的事情.相比起来,Python在web应用上的部署就繁杂的多,主要是工具繁多,主流服 ...

  6. windows下python web开发环境的搭建

    windows下python web开发环境: python2.7,django1.5.1,eclipse4.3.2,pydev3.4.1 一. python环境安装 https://www.pyth ...

  7. 我的第一个python web开发框架(1)——前言

    由于之前经验不是很丰富,写的C#系统太过复杂,所以一直想重写,但学的越多越觉得自己懂的越少,越觉的底气不足.所以一直不敢动手,在内心深处对自己讲,要静下心来认真学习,继续沉淀沉淀.这两年多以来找各种机 ...

  8. python web框架之Tornado

    说Tornado之前分享几个前端不错的网站: -- Bootstrap http://www.bootcss.com/ -- Font Awesome http://fontawesome.io/ - ...

  9. 一步一步理解 python web 框架,才不会从入门到放弃

    要想清楚地理解 python web 框架,首先要清楚浏览器访问服务器的过程. 用户通过浏览器浏览网站的过程: 用户浏览器(socket客户端) 3. 客户端往服务端发消息 6. 客户端接收消息 7. ...

  10. 我的第一个python web开发框架(41)——总结

    我的第一个python web开发框架系列博文从17年6.7月份开始写(存了近十章稿留到9月份才开始发布),到今天结束,一年多时间,想想真不容易啊. 整个过程断断续续,中间有段时间由于工作繁忙停了好长 ...

随机推荐

  1. CURL命令学习三

    -I 只获取请求头 -k --insecure 每次SSL连接curl都需要验证是否安全.-k参数表示如果不安全也可以继续操作. -4 --ipv4 告诉curl只使用ipv4地址 -6 --ipv6 ...

  2. Python面向对象-定制方法

    Python中的class可以定义许多定制方法,可以让我们方便的生成特定的类. 我们之前介绍了__slots__.__len__(),python中还有许多这样的特殊函数: __str__ >& ...

  3. cesium计算当前地图范围extent以及近似当前层级zoom

    前言 cesium 官网的api文档介绍地址cesium官网api,里面详细的介绍 cesium 各个类的介绍,还有就是在线例子:cesium 官网在线例子,这个也是学习 cesium 的好素材. 内 ...

  4. 搭建API Mock

    所需环境 Node.js + MySQL 5.7+ Redis 4.0+ Node.js 安装 .要安装nvm,需要安装构建源包所需的工具,CentOS 上安装,用这些命令来安装构建工具: sudo ...

  5. springboot~mybatis枚举映射

    在mybatis和mybatis plus里,如果你的实体字段是一个枚举类型,而在数据表里是整型,这时在存储时需要进行处理,默认情况下,会把枚举的元素名称拼接到SQL语句里,而由于数据表是int类型, ...

  6. SSM框架之SpringMVC(6)异常处理及拦截器

    SpringMVC(6)异常处理及拦截器 1.异常处理 1.1.异常处理的思路 ​ 系统中异常包括两类:预期异常和运行时异常 RuntimeException,前者通过捕获异常从而获取异常信息,后者主 ...

  7. Python 标准类库-数字和数学模块之decimal使用简介

    标准类库-数字和数学模块之decimal使用简介 by:授客 QQ:1033553122 例子 >>>from decimal import * >>>getcon ...

  8. SQLserver、MySQL、ORCAL查询数据库、表、表中字段以及字段类型

    一.SQLServer命令 1.查询SQLServer中的每个数据库 SELECT * from sysdatabases 2.查询SQLServer中指定数据库的所有表名 select name f ...

  9. Owhat sign参数分析

    需求:Owath进行商品购买时,psot提交的参数,有个sign,分析生成的算法. 1)点击商品购买后,进行抓包. 2)搜索sign定位赋值函数,OWAPIParamsDict paramsDictW ...

  10. Java8特性Lambda表达式

    Lambda 表达式 简介: Lambda 表达式,也可称为闭包,它是推动 Java 8 发布的最重要新特性. Lambda 允许把函数作为一个方法的参数(函数作为参数传递进方法中). (parame ...