<玩转Django2.0>读书笔记:表单
1. 表单字段
参考:
2. 表单代码示例(forms.Form)
# form.py代码
# 获取数据库数据
choices_list = [(i+1,v['typename']) for i,v in \
enumerate(ProductType.objects.values('typename'))]
# 自定义数据验证函数
def price_validate(value):
if int(value) <= 0:
print("******已进入验证******")
raise ValidationError("请输入正确价格")
class ProductForm(forms.Form):
# 设置错误信息并设置样式
name = forms.CharField(max_length=20,\
label="名字",\
# 参数widget是一个forms.widget对象,起作用是是设置表单字段CSS样式
widget=forms.widgets.TextInput(attrs={"class":"c1"}),\
# 用于数据验证失败后的错误信息
error_messages={"required":"名字不能为空"})
tttype = forms.ChoiceField(choices=choices_list,\
label="产品类型",\
widget = forms.widgets.Select(attrs={"class":"type","size":"4"}))
price = forms.DecimalField(max_digits=6,\
decimal_places=2,\
label="销售价格",\
# 自定义数据验证函数
validators = [price_validate])
<!-- form.html代码 -->
{% if product.errors %}
<p>
数据出差啦!出错信息:{{product.errors}}
</p>
{% else %}
<form action="" method="post">
{% csrf_token %}
<table>
{{product.as_table}}
</table>
<input type="submit" value="提交">
</form>
{% endif %}
# views.py中代码
def form_views(request):
if request.method == "GET":
product = ProductForm()
return render(request,'form.html',locals())
else:
product = ProductForm(request.POST)
if product.is_valid():
# 获取网页控件name的数据
# cleaned_data 将控件的数据进行清洗,转换成Python数据类型
name = product.cleaned_data['name']
tttype = product.cleaned_data['tttype']
price = product.cleaned_data['price']
print('*'*20,name,tttype,price)
return HttpResponse('提交成功')
else:
# 将错误信息输出,error_msg试讲错误信息以json格式输出
error_msg = product.errors.as_json()
print(error_msg)
return render(request,"form.html",locals())
- 将表单生成HTML的ul标签
{{product.as_ul}} - 将表单生成HTML的p标签
{{product.as_p}} - 生成单个HTML元素控件
{{product.type}} - 获取表单字段的参数label属性值
{{product.type.label}}
3. 表单插件weiget
参考:
4. 表单代码示例(forms.ModelForm)
forms.ModelForm是在forms.Form基础上结合模型所生成的数据表单.数据表单是将模型的字段转换成表单的字段,再从表单生成HTML的元素控件,这是日常开发中常用的表单之一
# forms代码
from django import forms
from django.core.exceptions import ValidationError
from .models import *
class ProductModelForm(forms.ModelForm):
# 添加模型外的表单字段
productId = forms.CharField(max_length=20,label="产品序号")
# 模型与表单设置
class Meta:
# 绑定模型
model = Product
# field属性用于设置转换字段,'__all__'是将全部模型字段转换成表单字段
# fields = "__all__"
# fields = ["name","tttype","price","weight"]
# exclude用于禁止模型字段转换成表单字段
exclude = ["ttype"]
# label设置HTML元素控件label标签
labels = {
"name" : "产品名称",
"tttype" : "产品类型",
"price" : "产品价格",
"weight" : "产品重量"
}
# 定义widgets,设置表单字段的CSS样式
widgets = {
"name" : forms.widgets.TextInput(attrs={"class":"c1"}),
"tttype" : forms.widgets.Select(attrs={"class":"type","size":"4"})
}
# 定义字段类型,一般情况下模型的字段会自动转换成表单字段
field_classes = {
"name" : forms.CharField
}
# 帮助提示信息
help_texts = {
"price" : "应该大于0"
}
# 自定义错误信息
error_texts = {
# __all__ 设置全部错误信息
"__all__" :{
"required" : "请输入内容",
"invalid" : "请检查输入内容"
},
# 设置摸个字段的错误信息
"price" : {
"required" : "请输入价格",
"invalid" : "请检查数值是否正确"
}
}
# 自定义表单字段weight的数据清洗
def clean_weight(self):
data = self.clean_data["weight"]
return data + "g"
模型字段类型为
ForeignKey和ManyToManyField,在表单中对应的表单字段为ModelChoiceField和ModelMultipleChoiceField在自定义数据清洗函数时,必须以"clean_字段名"的格式作为函数名,而且函数必须有return返回值
def modelform_views(request,id):
if request.method == "GET":
instance = Product.objects.filter(id=id).first()
# 判断数据是否存在
if instance:
product = ProductModelForm(instance=instance)
else:
product = ProductModelForm(initial={"name":"mi","price":1999})
return render(request,'form.html',locals())
else:
product = ProductModelForm(request.POST)
if product.is_valid():
# 获取weight的数据,并通过clean_weight进行清洗
weight = product.cleaned_data["weight"]
# # 数据保存方法一
# # 直接将数据保存到数据库
# product.save()
# # 数据保存方法二
# # save方法设置commit=False,将生成数据库对象product_db,
# # 然后对该对象的属性值修改并保存
# product_db = product.save(commit=False)
# product_db.name = "new" + product_db.name
# product_db.save()
# 数据保存方法三
# save_m2m()方法用于保存ManyToMany的数据模型
# product.save_m2m()
return HttpResponse("提交成功!weight清洗后的数据为" + weight)
else:
# 将错误信息输出,error_msg是将错误信息以json格式输出
error_msg = product.errors.as_json()
print('*'*20,error_msg)
return render(request,'form.html',locals())
表单初始化4种方法
ProductModelForm(initial={'name':value}),适用于所有表单ProductModelForm(instance=object),只适用于ModelForm定义表单时,可以对表单字段设置初始化参数initial,此方法不适用于ModelForm,如
name=forms.CharField(initial=value)重写表单类的初始化函数__init__(),适用于所有表单类, 如在初始化函数__init__()中设置
self.field['name'].inital=value
<玩转Django2.0>读书笔记:表单的更多相关文章
- <玩转Django2.0>读书笔记:模板和模型
1. 模板内置标签 Django常用内置标签 标签 描述 {% for %} 遍历输出变量的内容 {% if %} 对变量进行条件判断 {% csrf_token %} 生成csrf_token标签, ...
- <玩转Django2.0>读书笔记:邮件和分页
1. 发送邮件 # settings.py设置 # 邮箱设置 EMAIL_USE_SSL = True # 邮件服务器 EMAIL_HOST = 'smtp.qq.com' # 邮件服务端口 EMAI ...
- <玩转Django2.0>读书笔记:URL规则和视图
1. 带变量的URL #urls.py from django.urls import path from .view import * urlpatterns = [ path('',index_v ...
- 【Django笔记四】Django2.0中的表单
一.环境版本信息: 操作系统:windows10 Django版本:2.0.5 Python版本:3.6.4 Mysql版本: 5.5.53 安装mysql 二.基础信息 1.App中的模型mod ...
- 《玩转Django2.0》读书笔记-Django配置信息
<玩转Django2.0>读书笔记-Django配置信息 作者:尹正杰 版权声明:原创作品,谢绝转载!否则将追究法律责任. 项目配置是根据实际开发需求从而对整个Web框架编写相应配置信息. ...
- 《玩转Django2.0》读书笔记-Django建站基础
<玩转Django2.0>读书笔记-Django建站基础 作者:尹正杰 版权声明:原创作品,谢绝转载!否则将追究法律责任. 一.网站的定义及组成 网站(Website)是指在因特网上根据一 ...
- 《玩转Django2.0》读书笔记-探究视图
<玩转Django2.0>读书笔记-探究视图 作者:尹正杰 版权声明:原创作品,谢绝转载!否则将追究法律责任. 视图(View)是Django的MTV架构模式的V部分,主要负责处理用户请求 ...
- 《玩转Django2.0》读书笔记-编写URL规则
<玩转Django2.0>读书笔记-编写URL规则 作者:尹正杰 版权声明:原创作品,谢绝转载!否则将追究法律责任. URL(Uniform Resource Locator,统一资源定位 ...
- 9. Javascript学习笔记——表单处理
9. 表单处理 9.1 表单的基础知识 ///表单用 <form> 元素表示,对应的是 HTMLFormElement 类型,继承自 HTMLElement. //属性:action.me ...
随机推荐
- [Android] Android 支持下拉刷新、上拉加载更多 的 XRecyclerview
XRecyclerView一个实现了下拉刷新,滚动到底部加载更多以及添加header功能的的RecyclerView.使用方式和RecyclerView完全一致,不需要额外的layout,不需要写特殊 ...
- Technocup 2019 - Elimination Round 1
http://codeforces.com/contest/1030 B. Vasya and Cornfield 判断点是否在矩形内(包括边界) 把每条边转化为一个不等式 public static ...
- 题解 P1801 【黑匣子_NOI导刊2010提高(06)】
蒟蒻来发题解了.我仔细看了一下其他题解,各位巨佬用了堆,红黑树,splay,treap之类的强大算法,表示蒟蒻的我只会口胡这些算法,所以我决定用一种极其易理解的算法————fhq treap,作为tr ...
- Node的express配置使用ejs模板
注册ejs模板为html页.以.ejs为后缀的模板页,现在的后缀名可以是.html app.engine('.html', require('ejs').__express); 设置视图模板的默认后缀 ...
- svn 解决冲突
当svn update时提示如下: D C main.go > local file unversioned, incoming file add upon updateSummary of c ...
- temp 和 tmp 文件
TMP和TEMP文件是各种软件或系统产生的临时文件,也就是常说的垃圾文件.Windows产生的临时文件,本质上和虚拟内存没什么两样,只不过临时文件比虚拟内存更具有针对性,单独为某个程序服务而已.而它的 ...
- git怎样删除未监视的文件untracked files
# 删除 untracked files git clean -f # 连 untracked 的目录也一起删掉 git clean -fd # 连 gitignore 的untrack 文件/目录也 ...
- C++ 常见面试题目
const作用 (1)可以定义const常量,具有不可变性. (2)便于进行类型检查.(而宏不会进行类型检查). (3)可以保护被修饰的东西,防止意外的修改. (4) 可以节省空间. static作用 ...
- vue 生命周期详解
- pythonのdjango select_related 和 prefetch_related()
在数据库有外键的时候,使用select_related() 和 prefetch_related() 可以很好的减少数据库请求次数,从而提高性能. (1)select_related()当执行它的查询 ...