具体可参考:http://www.liujiangblog.com/course/django/153

https://www.cnblogs.com/liuguniang/p/7141837.html

https://www.cnblogs.com/liwenzhou/p/8747872.html

一,Form字段:

1)验证

2)生成HTML(保留上次输入内容)

3)初始化默认值

Form 重点字段:

------ChoiceField *****8

------MultipleChoiceField

------CharField

------IntegerField

------DecimalField

------DateField

------DateTimeField

------EmailField

------GenericIPAdressField--

------FileField

------RegexField

三,具体用法:

1)CharField的参数

class TestForm(forms.Form):
user = fields.CharField(
required=True, # 是否必填
max_length=12, # 最大长度
min_length=3, # 最小长度
error_messages={ # 错误提示
'required':''
},
# widget = widgets.Textarea, # 定制html插件
# widget=widgets.Select,
label="用户名",
initial='请输入用户名', # 默认值
show_hidden_initial=False, # 是否在当前插件在家一个隐藏的且具有默认值的插件(可用于检验两次输入是否一致)
validators=[], # 自定制验证规则(是否是手机号)
localize=False, # 是否支持本地化
disabled=True, # 是否可以编辑
label_suffix=":", )
age = fields.IntegerField(label="年龄",)
email = fields.EmailField(label="邮箱",)
当widget = widgets.Textarea 展示效果如下

当widget=widgets.Select展示效果如下

2)

简单了解
1){{ obj.as_p }}
2)
<ul>
{{ obj.as_ul }}
</ul>
3)
<table>
{{ obj.as_table}}
</table>

3)IntegerField类型

age = fields.IntegerField(
label="年龄",
max_value=12,
min_value=5,
error_messages={
'max_value' : "太大了"
}
)

4)DecimalField类型

	weight = fields.DecimalField(
label = "体重",
max_value=30, # 最大值
min_value=10, # 最小值
max_digits=5, #总长度
decimal_places=3, #小数位的长度 )

5)RegexField正则

6)EmailField

7)URLField

8)FileField

img = fields.FileField(label="上传文件")

.html中

novalidate enctype="multipart/form-data"

9)ChoiceField

	city = fields.ChoiceField(
label="城市",
choices=[(1,"上海"),(2,"北京"),(3,"天津"),],
initial = 2, )

10)MultipleChoiceField

hobby = fields.MultipleChoiceField(
label="爱好",
choices=[(1, "篮球"), (2, "足球"), (3, "乒乓球"), ],
initial=[1, 2], # 多选是列表
)

11)TypeChoiceField 转换类型的,打印输出的chocices 1不是字符串类型而是int类型

city = fields.TypedChoiceField(
coerce=lambda x: int(x),#转换类型
label="城市",
choices=[(1, "上海"), (2, "北京"), (3, "天津"), ],
initial=2, # 单选是单值 )

二.Form 之 插件:每一个fields字段都是一个正则表达式+默认的插件组成的,

1)更改默认插件:

widget = widgets.TextInput(attrs={'n':123}), #加自定义属性

2)如果想把

txt = "<input type = 'text/>" 标签类的文本展示到页面上,需要在view传值的页面加上
from  django.utils.safestring import mark_safe

txt =mark_safe("<input type = 'text/>")

3)Django 的内置插件: 单选的两种写法如下: select

只有select 有choice input什么的没有
xdb = fields.CharField(
widget=widgets.Select(choices=[(1,"11"),(2,"22"),])
) 也可以直接用ChoiceField
xdb = fields.ChoiceField( 
choices=[(1,"11"),(2,"22"),]
)

多选的写法如下:

xdb = fileds.MultipleChoiceField(
choices = [(1,"111"),(2,"222")]
widget = widgets.SelectMultiple(attrs = {"class":"cl"})
)

4)checkbox(单选的)

	xdb = fields.CharField(
# widget=widgets.Select(choices=[(1,"11"),(2,"22"),])
widget=widgets.CheckboxInput()
)

5)checkbox(多选的)

	xdb = fields.MultipleChoiceField(
initial=[2,],
choices = [(1, "篮球"), (2, "足球"), (3, "乒乓球"), ],
# widget=widgets.Select(choices=[(1,"11"),(2,"22"),])
widget=widgets.CheckboxSelectMultiple()
)

6)radio

	xdb = fields.ChoiceField(
initial=[2,],
choices = [(1, "篮球"), (2, "足球"), (3, "乒乓球"), ],
# widget=widgets.Select(choices=[(1,"11"),(2,"22"),])
widget=widgets.RadioSelect()
)

三.特殊的单选或者多选时,数据源是否能实时更新????/

https://www.cnblogs.com/

Django 之Form的更多相关文章

  1. Django之Form组件

    Django之Form组件 本节内容 基本使用 form中字段和插件 自定义验证规则 动态加载数据到form中 1. 基本使用 django中的Form组件有以下几个功能: 生成HTML标签 验证用户 ...

  2. Django models Form model_form 关系及区别

    Django models Form model_form

  3. 【Django】--Form组件

    Django的Form主要具有一下几大功能: 生成HTML标签 验证用户数据(显示错误信息) HTML Form提交保留上次提交数据 初始化页面显示内容 例子: 1.创建Form类 from djan ...

  4. Django基础——Form&Ajax篇

    一 Form 在实际的生产环境中,登录和注册时用户提交的数据浏览器端都会使用JavaScript来进行验证(比如验证输入是否为空以及输入是否合法),但是浏览器可能会禁用JavaScirpt,同时也有人 ...

  5. Python之路【第二十一篇】:Django之Form组件

    Django之Form组件   Django的Form主要具有一下几大功能: 生成HTML标签 验证用户数据(显示错误信息) HTML Form提交保留上次提交数据 初始化页面显示内容 小试牛刀 1. ...

  6. 第十一篇:web之Django之Form组件

    Django之Form组件   Django之Form组件 本节内容 基本使用 form中字段和插件 自定义验证规则 动态加载数据到form中 1. 基本使用 django中的Form组件有以下几个功 ...

  7. 69、django之Form组件

    本篇导航: 小试牛刀 Form类 常用选择插件 自定义验证规则 初始化数据 Django的Form主要具有一下几大功能: 生成HTML标签 验证用户数据(显示错误信息) HTML Form提交保留上次 ...

  8. Django的Form(二)

    上一篇已经简单介绍了Django的Form,现在开始进阶操作了 ..... 创建Form类的时候,主要涉及到Form字段和Form的插件,字段用于做form验证,插件用来生成HTML DjiangoF ...

  9. Django的Form

    Django的Form有两个基本用途: 1.用于生成html的Form表单 2.用于后台做表单验证 #!/usr/bin/env python # -*- coding:utf-8 -*- impor ...

  10. python Django之Form组件

    python Django之Form组件 Django的Form主要具有一下几大功能: 生成HTML标签 验证用户数据(显示错误信息) HTML Form提交保留上次提交数据 初始化页面显示内容 小试 ...

随机推荐

  1. JSON 使用

    ylbtech-JSON: JSON 使用 1. 把 JSON 文本转换为 JavaScript 对象返回顶部 JSON 最常见的用法之一,是从 web 服务器上读取 JSON 数据(作为文件或作为 ...

  2. NodeJs使用Express框架开发时的快速调试方法

    习惯了php开发,可以直接使用echo或者var_dump()将想要查看的变量结果输出到网页查看,非常的方便.但是使用express开发时,每次修改文件后,都需要使用npm start命令重启服务,然 ...

  3. Jmeter(四十一)分布式测试(转!)

    寄语路人休掩鼻,活人不及死人香. -------<随园诗话>袁枚 转自:https://www.cnblogs.com/imyalost/p/8306866.html 1.修改Contor ...

  4. ArcGIS for android添加图层几何体

    GraphicLayer lyr; Map<String,Object> attr = new HashMap<String,Object>(); attr.put(this. ...

  5. 俞敏洪:我创业24年感悟的3条CEO守则

    转自:http://www.gamelook.com.cn/2017/10/306603 创业24年,他的创业经历被拍成了电影.在一次小范围聚会时,他说现实远比剧本要精彩.“如果让我一切从头开始,我会 ...

  6. ip route 命令详解

    linux的ip命令和ifconfig类似,但前者功能更强大,并旨在取代后者.使用ip命令,只需一个命令,你就能很轻松地执行一些网络管理任务.ifconfig是net-tools中已被废弃使用的一个命 ...

  7. module 'pip' has no attribute 'pep425tags'

    AMD64 import pip._internal print(pip._internal.pep425tags.get_supported()) 1 2 WIN32 import pip prin ...

  8. python学习笔记-学习大纲

  9. SSH2 No Session found for current thread原因

    Hibernate4 与 spring3 集成之后, 如果在取得session 的地方使用了getCurrentSession, 可能会报一个错:“No Session found for curre ...

  10. 《Linux 性能及调优指南》2.4 基准工具

    翻译:飞哥 (http://hi.baidu.com/imlidapeng) 版权所有,尊重他人劳动成果,转载时请注明作者和原始出处及本声明. 原文名称:<Linux Performance a ...