具体可参考: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. 廖雪峰Java1-4数组操作-5命令行参数

    adb和ideviceinstaller提供了许多参数供我们使用.命令行参数提供了这样的入口,针对不同的参数执行不同的命令. 1.命令行参数 命令行参数是一个String[] 数组,由JVM接收用户输 ...

  2. UnicodeString基本操作(Ring0)

    #include "Unicode_String_Ring0.h" //bp Unicode_String_Ring0!DriverEntry NTSTATUS DriverEnt ...

  3. 记录Linux下解压大文件时的一次奇葩经历

    由于需要安装新的系统,使用wget下载tar包,8G多下载了1个多小时.解压完后的文件夹中的tar包数量明显不够,而且原始的tar包竟然不见了. 同样的操作又进行了一次,结果还是一样,不得不怀疑是哪里 ...

  4. PHP中的static的理解

    静态方法 (1)静态方法不能访问这个类中的普通属性,因为那些属性属于一个对象,但可以访问静态属性: (2)从当前类(不是子类)中访问静态方法或属性,可以使用 self 关键字,self 指向当前类,就 ...

  5. switch语句的功能是否完全可以使用if else多选择结构来代替?如果是,为什么还需要switch结构?

  6. [UE4]Vertical Box结合Horizontal Box创建出类似微信的经典手机界面

    头部标题,中部为自动填充,底部为一个Horizontal Box,其中的“通讯录”文字比较宽,需要设置Size.Fill=1.5

  7. 超实用!9个目前流行的MATERIAL DESIGN前端框架

    http://www.uisdc.com/material-design-frameworks-top-9 谷歌推出的Material Design风格已见有一些APP UI采用,视觉和交互体验都很棒 ...

  8. 分段覆盖率TPR

    黑产监控中,需要尽可能做到尽可能少的误伤和尽可能准确地探测,可以选择“在FPR较低时的TPR加权平均值”作为平均指标. 根据混淆矩阵计算TPR(覆盖率)和FPR(打扰率): 覆盖率:TPR = TP ...

  9. 第7章 网络层协议(2)_ICMP协议

    2. ICMP协议 2.1 ICMP报文(Internet Control Message Protocol)的类型 报文类型 类型值 代码 描述 请求报文 8 0 请求回显报文 响应报文 0 0 回 ...

  10. WebBrowser常用属性方法介绍

    WebBrowser 常用属性方法 ■■方法 ==============================  ▲GoBack    相当于IE的"后退"按钮,使你在当前历史列表中后 ...