django表单的api
django表单的api,参考文档:https://yiyibooks.cn/xx/Django_1.11.6/ref/forms/api.html
绑定与未绑定形式:
Form
要么是绑定的,要么是未绑定的。
- 如果是绑定的,那么它能够验证数据,并渲染表单及其数据成HTML。
- 如果未绑定,则无法进行验证(因为没有数据可以验证!),但它仍然可以以HTML形式呈现空白表单。
我们有如下表单实例:
from django import forms
class UserInfo(forms.Form):
username = forms.CharField(label=u"用户名", max_length=50)
mobile = forms.CharField(label=u"手机号", max_length=20)
subject = forms.CharField(label=u"主题", max_length=50)
绑定一个表单
>>> data = {"username":"jobs","mobile":"123456789", "subject":"Hello, World"}
>>> user = UserInfo(data) #把上面字典绑定到表单上。
>>> user.is_bound #检查表单是否绑定
True >>> u1 = UserInfo({}) #即便传入的是一个空的字典,也会绑定
>>> u1.is_bound
True
使用表单验证数据
Form.
clean
()
当你需要为相互依赖的字段添加自定义的验证时,你可以重写Form
的clean()
方法。[...]
Form.
is_valid
()
Form
对象的首要任务就是验证数据。 对于绑定的Form
实例,可以调用is_valid()
方法来执行验证,该方法会返回一个表示数据是否合法的布尔值。
>>> user.is_valid()
True >>> date = {"username":"jobs","mobile":123456789, "subject":" "} #把subject的值设为空。
>>> u2 = UserInfo(date)
>>> u2.is_valid()
False
Form.
errors
访问errors
属性可以获得错误信息的一个字典:
>>> u2.errors
{'subject': [u'This field is required.']}
在这个字典中,键为字段的名称,值为表示错误信息的Unicode 字符串组成的列表。 错误信息保存在列表中是因为字段可能有多个错误信息。
你可以在调用is_valid()
之前访问errors
。 表单的数据将在第一次调用is_valid()
或者访问errors
时验证。
验证只会调用一次,无论你访问errors
或者调用is_valid()
多少次。 这意味着,如果验证过程有副作用,这些副作用将只触发一次。
有关错误信息还有几个方法如下,用到的时候再说明。
Form.errors.as_data()
Form.errors.as_json(escape_html=False)
Form.add_error(field, error)
Form.has_error(字段,code = None)
Form.non_field_errors() #地址
动态初始值
Form.
initial
在运行时,可使用initial
声明表单字段的初始值。 例如,你可能希望使用当前会话的用户名填充username
字段。
使用Form
的initial
参数可以实现。 该参数是一个字典。 只包括您指定初始值的字段;没有必要在表单中包含每个字段。
>>> u3 = UserInfo(initial={"username": "king"})
>>> u3["username"]
<django.forms.boundfield.BoundField object at 0x00000000046D6AC8>
>>> u3["username"].value()
'king'
如果一个Field
包含initial
参数,并且你在实例化Form
时又包含了一个initial
参数,那么后一个initial
优先级高。
Form.
get_initial_for_field(field,field_name)
使用get_initial_for_field()
来检索表单字段的初始数据。 它以该顺序从Form.initial
和Field.initial
中检索数据,并评估任何可调用的初始值。
Form.
has_changed
()
当你需要检查表单的数据是否从初始数据发生改变时,(和初始数据比较发生变化)可以使用Form的has_changed()方法。
>>> data = {"username":"king", "mobile":"123456789", "subject":"Fucking"}
>>> f = UserInfo(data, initial=data) #data是我们绑定的数据,initial是表示的初始的数据,当然这里是一样没有改变。
>>> f.has_changed()
False
当提交表单时,我们可以重新构建表单并提供初始值,这样可以实现比较:
>>> f = ContactForm(request.POST, initial=data)
>>> f.has_changed()
如果request.POST 中的数据与initial 中的不同,has_changed() 将为True,否则为False。 计算的结果是通过调用表单每个字段的Field.has_changed() 得到的。
Form.
changed_data
changed_data属性返回一个列表,包含那些在表单的绑定数据中的值(通常为request.POST)与原始值发生改变的字段的名字。 如果没有数据不同,它返回一个空列表。
>>> data1 = {"username":"king", "mobile":"", "subject":"what a Fucking"} #迷你更改
>>> f2 = UserInfo(data1, initial=data)
>>> f2.has_changed()
True
>>> f2.changed_data
['subject']
访问表单中的字段
Form.
fields
你可以从Form
实例的fields
属性访问字段:
>>> for item in f.fields:
... print item
...
username
mobile
subject >>> f.fields["username"] #返回的是一个django.forms.fields.CharField 对象
<django.forms.fields.CharField object at 0x00000000044B7080>
访问干净的数据
Form.
cleaned_data
Form
类中的每个字段不仅负责验证数据,还负责“清洁”它们 —— 将它们转换为正确的格式。 这是个非常好用的功能,因为它允许字段以多种方式输入数据,并总能得到一致的输出。
例如,DateField
将输入转换为Python 的 datetime.date
对象。 无论你传递的是DateField
格式的字符串、datetime.date
对象、还是其它格式的数字,'1994-07-15'
将始终将它们转换成datetime.date
对象,只要它们是合法的。
一旦你创建一个Form
实例并通过验证后,你就可以通过它的cleaned_data
属性访问清洁的数据:
>>> f.is_valid()
True
>>> f.cleaned_data
{'username': u'king', 'mobile': u'', 'subject': u'Fucking'} #注意,文本字段 —— 例如,CharField
和EmailField
—— 始终将输入转换为Unicode 字符串。
如果你的数据没有 通过验证,cleaned_data
字典中只包含合法的字段:
>>> data1
{'username': 'king', 'mobile': '', 'subject': ''}
>>> f3 = UserInfo(data1)
>>> f3.is_valid()
False
>>> f3.cleaned_data
{'username': u'king', 'mobile': u''}
cleaned_data
始终只 包含Form
中定义的字段,即使你在构建Form
时传递了额外的数据,cleaned_data也不会显示。
当Form
合法时,cleaned_data
将包含所有字段的键和值,即使传递的数据不包含某些可选字段的值。
>>> data2 = {'username': u'king', 'mobile': u''} #我们需要4个字段的值,但是这里给出了三个
>>> f3 = UserInfo(data2)
>>> f3.is_valid() #这里我自己测试的时候结果是False,但是官方文档给出的结果是True;
False
>>> f3.cleaned_data #这个结果是一致的
{'username': u'king', 'mobile': u''}
输出表单为HTML
我们知道表单本质就是html文档的展示,那么我们如何查看表单的html格式呢?
>>> f4 = UserInfo()
>>> print f4 #直接使用print打印实例化的实例即可,如果表单是绑定的输出的表单将会包含数据
<tr><th><label for="id_username">用户名:</label></th><td><input id="id_username" maxlength="" name="username" type="text" required /></td></tr>
<tr><th><label for="id_mobile">手机号:</label></th><td><input id="id_mobile" maxlength="" name="mobile" type="text" required /></td></tr>
<tr><th><label for="id_subject">主题:</label></th><td><input id="id_subject" maxlength="" name="subject" type="text" required /></td></tr>
#查看每个表单的value属性。
>>> print f3
<tr><th><label for="id_username">用户名:</label></th><td><input id="id_username" maxlength="" name="username" type="text" value="king" required /></td></tr>
<tr><th><label for="id_mobile">手机号:</label></th><td><input id="id_mobile" maxlength="" name="mobile" type="text" value="" required /></td></tr>
<tr><th><label for="id_subject">主题:</label></th><td><ul class="errorlist"><li>This field is required.</li></ul><input id="id_subject" maxlength="" name="subject" type="text" required /></td></tr>
默认的输出时具有两个列的HTML 表格,每个字段对应一个<tr>。 注意事项: 为了灵活性,输出不包含</table> 和<table>、</form> 和<form> 以及<input type="submit"> 标签。 你需要添加它们。
每个字段类型都有一个默认的HTML表示。 CharField is represented by an <input type="text"> and EmailField by an <input type="email">. BooleanField
表示为一个<input type="checkbox">。 注意,这些只是默认的表示;你可以使用Widget 指定字段使用哪种HTML,我们将稍后解释。
每个标签的HTML name 直接从ContactForm 类中获取。
每个字段的文本标签 —— 例如'Message:'、'Subject:' 和'Cc myself:' 通过将所有的下划线转换成空格并大写第一个字母生成。 再次注意,这些只是明智的违约;您也可以手动指定标签。
每个文本标签周围有一个HTML <label> 标签,它指向表单字段的id。 这个id,是通过在字段名称前面加上'id_' 前缀生成。 id 属性和<label> 标签默认包含在输出中,但你可以改变这一行为。
输出使用HTML5语法,目标是&lt;!DOCTYPE html&gt;。 例如,它使用布尔属性,如checked,而不是checked='checked'的XHTML样式。
Form.
as_p
()
<p>
渲染表单为一系列的<p>
标签,每个as_p()
标签包含一个字段:
Form.
as_ul
()
<li>
渲染表单为一系列的<li>
标签,每个as_ul()
标签包含一个字段。 它不包含</ul>
和<ul>
,所以你可以自己指定<ul>
的任何HTML 属性:
Form.
as_table >()
最后,as_table()
输出表单为一个HTML <table>
。 它与print
完全相同。 事实上,当你print
一个表单对象时,在后台调用的就是as_table()
方法:
>>> f4.as_p() #注意这里,返回的是一个unicode字段。
u'<p><label for="id_username">\u7528\u6237\u540d:</label> <input id="id_username" maxlength="50" name="username" type="text" required /></p>\n<p><label for="id_mobile">\u624b\u673a\u53f7:</label> <input id="id_mobile" maxlength="20" name="mobile" type="text" required /></p>\n<p><label for="id_subject">\u4e3b\u9898:</label> <input id="id_subject" maxlength="50" name="subject" type="text" required /></p>'
>>> print f4.as_p()
<p><label for="id_username">用户名:</label> <input id="id_username" maxlength="" name="username" type="text" required /></p>
<p><label for="id_mobile">手机号:</label> <input id="id_mobile" maxlength="" name="mobile" type="text" required /></p>
<p><label for="id_subject">主题:</label> <input id="id_subject" maxlength="" name="subject" type="text" required /></p>
设置特殊提示
必填的表单和有错误的表单很常见,可以单独为其定义CSS样式。django有两个钩子,可以根据需求添加对应的属性。【把官网实例放这里】
Form.error_css_class
和Form.required_css_class
属性就是做这个用的:
from django import forms class ContactForm(forms.Form):
error_css_class = 'error'
required_css_class = 'required' # ... and the rest of your fields here
属性名是固定的,不可变(废话),通过赋值不同的字符串,表示给这两类属性添加不同的CSS的class属性。以后Django在渲染form成HTML时将自动为error和required行添加对应的CSS样式。
上面的例子,其HTML看上去将类似:
>>> f = ContactForm(data)
>>> print(f.as_table())
<tr class="required"><th><label class="required" for="id_subject">Subject:</label> ...
<tr class="required"><th><label class="required" for="id_message">Message:</label> ...
<tr class="required error"><th><label class="required" for="id_sender">Sender:</label> ...
<tr><th><label for="id_cc_myself">Cc myself:<label> ...
>>> f['subject'].label_tag()
<label class="required" for="id_subject">Subject:</label>
>>> f['subject'].label_tag(attrs={'class': 'foo'})
<label for="id_subject" class="foo required">Subject:</label>
django表单的api还有很多,暂时先列到这里,再续!
django表单的api的更多相关文章
- Django表单API详解
声明:以下的Form.表单等术语都指的的广义的Django表单. Form要么是绑定了数据的,要么是未绑定数据的. 如果是绑定的,那么它能够验证数据,并渲染表单及其数据,然后生成HTML表单.如果未绑 ...
- 第四章:Django表单 - 2:Django表单API详解
声明:以下的Form.表单等术语都指的的广义的Django表单. Form要么是绑定了数据的,要么是未绑定数据的. 如果是绑定的,那么它能够验证数据,并渲染表单及其数据,然后生成HTML表单.如果未绑 ...
- python 全栈开发,Day111(客户管理之 编辑权限(二),Django表单集合Formset,ORM之limit_choices_to,构造家族结构)
昨日内容回顾 1. 权限系统的流程? 2. 权限的表有几个? 3. 技术点 中间件 session orm - 去重 - 去空 inclusion_tag filter 有序字典 settings配置 ...
- python3之Django表单(一)
1.HTML中的表单 在HTML种,表单是在<form>...</form>种的元素,它允许用户输入文本,选择选项,操作对象等,然后发送这些数据到服务器 表单元素允许用户在表单 ...
- 9:django 表单
django自带表单系统,这个表单系统不仅可以定义属性名,还可以自己定义验证,更有自己自带的错误提示系统 这节我们仅仅粗略的来看一下django表单系统的入门运用(具体的实在太多东西,主要是我觉得有很 ...
- django 表单系统 之 forms.Form
继承forms.Form实现django表单系统 参考: https://www.cnblogs.com/zongfa/p/7709639.html https://www.cnblogs.com/c ...
- 关于创建Django表单Forms继承BaseForm的问题
在创建Django表单时,因为需要验证用户输入的验证码是否正确,因此需要在session里提取当前验证码的值和POST提交过来的值进行比对,如图: form.py from django import ...
- Django 表单处理流程
Django 的表单处理:视图获取请求,执行所需的任何操作,包括从模型中读取数据,然后生成并返回HTML页面(从模板中),我们传递一个包含要显示的数据的上下文.使事情变得更复杂的是,服务器还需要能够处 ...
- 第四章:Django表单 - 1:使用表单
假设你想从表单接收用户名数据,一般情况下,你需要在HTML中手动编写一个如下的表单元素: <form action="/your-name/" method="po ...
随机推荐
- [vue]vue路由篇vue-router
spa单页开发及vue-router基础: https://www.cnblogs.com/iiiiiher/p/9034496.html url两种传参方式 query: $route.query ...
- [LeetCode] 762. Prime Number of Set Bits in Binary Representation_Easy
Given two integers L and R, find the count of numbers in the range [L, R] (inclusive) having a prime ...
- zyb的面试(广工14届比赛)
这道题目在上半年ZOJ模拟上年青岛赛区ACM题的时候就已经出现了.当时我不会写,本来想着赛后补题的最后因为懒惰又没补. 现在这道题又出现了.这是上天对我的惩罚啊!!! 所以这次铁了心也要补这题.然后我 ...
- electron 前端开发桌面应用
electron是由Github开发,是一个用Html.css.JavaScript来构建桌面应用程序的开源库,可以打包为Mac.Windows.Linux系统下的应用. 快速开始 接下来,让代码来发 ...
- express框架之session 存储
1.express-session 是基于express框专门用于处理session的中间件.这里不谈express-session怎么安装,只给出相应的实例代码.另外,session的认证机制离不开 ...
- kdeplot(核密度估计图) & distplot
Seaborn是基于matplotlib的Python可视化库. 它提供了一个高级界面来绘制有吸引力的统计图形.Seaborn其实是在matplotlib的基础上进行了更高级的API封装,从而使得作图 ...
- keras模型的保存与重新加载
# 模型保存JSON文件 model_json = model.to_json() with open('model.json', 'w') as file: file.write(model_jso ...
- opencv-resize()放缩函数简介
主要介绍函数resize(); 图像缩放的效果图如下: 主程序代码及函数解释如下所示: /******************************************************* ...
- react native 中使用react-native-vector-icons
1.引入依赖 cnpm install react-native-vector-icons --save 2.LINK原生 react-native link react-native-vector- ...
- java.lang.ClassNotFoundException: org.hibernate.engine.FilterDefinition的解决方案
今天在GitHub上面看到一个有意思的项目,下载下来,使用tomcat部署失败,出现异常,网上说JDK版本太高,改低,还是失败. 由于本人有个习惯,更喜欢把项目直接放入tomcat webapps 里 ...