<玩转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 ...
随机推荐
- json 格式化的时候,日期格式化
public class CustomIsoDateTimeConverter : IsoDateTimeConverter { public CustomIsoDateTimeConverter() ...
- windows下搭建Kafka,并通过命令窗口收发消息
参考网址: https://blog.csdn.net/ydc321/article/details/70154278 前提条件:windows环境需要安装jdk 1.下载Kafka,可以通过官网下载 ...
- 开发一个项目之ES2015+
变量的解构赋值 任何部署了 Iterator 的对象都可 for of 循环(数组.Set.Map.某些类似数组的对象(arguments对象.DOM NodeList 对象).Generator 对 ...
- Leetcode#442. Find All Duplicates in an nums(数组中重复的数据)
题目描述 给定一个整数数组 a,其中1 ≤ a[i] ≤ n (n为数组长度), 其中有些元素出现两次而其他元素出现一次. 找到所有出现两次的元素. 你可以不用到任何额外空间并在O(n)时间复杂度内解 ...
- 看不到git远程分支
1.先用fetch命令更新remote索引 $ git fetch 2.再查看remote分支,发现已经可以看到目标分支 $ git branch -a 3.再切换分支 $ git checkout ...
- spring boot2.0.4集成druid,用jmeter并发测试工具调用接口,druid查看监控的结果
一.项目介绍(本项目用的编程语言是jdk8,项目源码:https://github.com/zhzhair/spring-boot-druid.git) 1.引入pom依赖: <dependen ...
- Mybatis 常用注解
Mybatis常用注解对应的目标和标签如表所示: 注解 目标 对应的XML标签 @CacheNamespace 类 <cache> @CacheNamespaceRef 类 <cac ...
- 【Flask】Flask学习笔记(一) 应用基本结构
初始化 使用前必须创建一个应用实例 from flask import Flask app = Flask(__name__) 路由和视图函数 请求流程 客户端(web浏览器)--> web服 ...
- 【Linux】常见基础命令之系统操作
linux现在基本上已成为面试的必考题目,特此总结一些常用的基础命令. cd:切换目录 lilip@ubuntu:~$ cd /home/lilip/test pwd:打印当前目录 lilip@ubu ...
- SpingBoot+Mybaits+Vue,更新学习
1.DTO 2.实体类 3.Controller层,UpdatePrize/{id}为接口 4.Service层 5.Impl实现层 之后就可以更新数据了. 6.Vue链接接口 7.请求,解析,返回值 ...