Django学习手册 - Form 插件
"""
核心:
from django import forms
from django.forms import fields
from django.forms import widgets
class table_name(forms.Form)
自定义字段名 = fields.字段数据类型(字段参数) 字段数据类型: 基本字段:
fields.CharField() #字符串类型
fields.IntegerField() #整型类型
fields.FloatField() #浮点类型
fields.EmailField() #邮箱
fields.DecimalField() #自定义浮点类型
自参数:
max_digits=20 #总长度
decimal_places=20 #小数长度 #文件类型
#html form上传时,enctype="multipart/form-data" ,views 中 request.FILES
fields.ImageField() #图片上传按钮。需要pillow模块
fields.filefield() #文件上传选项
fields.filepathfiled() #对应一个(文件组成的下拉菜单)选择,必须参数path=''.选项为这个地址里边所有的文件。
可选参数recursive=True是否包含子文件夹里的文件 #日期/时间
fields.DateField() #日期,格式:2015-09-01
fields.TimeField() #时间,格式:11:11
fields.DateTimeField() #日期时间,2000-01-01 11:11
fields.DurationField() #时间间隔,%d %H:%M:%S.%f #IP地址
fields.GenericIPAddressField() #ip地址类型 #选择框
fields.booleanfield() #checkbox选择框 fields.ChoiceField() #choice类型 单选框(返回的值为字符串)
fields.MultipleChoiceField() #choice类型 多选框 多值为列表(返回的值为字符串)
自参数:
choices=[(1,'A'),(2,'B'),(3,'C')]
fields.TypedChoiceField() #choice类型 单选框(返回的值可定制)
fields.TypedMultipleChoiceField() #choice类型 多选框 多值为列表(返回的值可定制)
自参数:
coerce = lambda x : int(x)
choices=[(1,'A'),(2,'B'),(3,'C')] #自定制
fields.RegexField() #自定义属性
自参数:
regx #自定义正则表达式 FORM 字段参数:
required=True, #必填
max_length=20, #最大值
min_length=5, #最小值
error_messages="required":'不能为空!'}, #错误信息
label="用户名" #标签名
initial="请输入用户名" #默认值
show_hidden_initial=True/False #隐藏,且保存上次数据(检测两次输入)
validators=[] #自定制验证规则
localsize=True/False #是否支持本地化
disabled =True/False #是否能编辑
widget #定制HTML插件
1.自定义显示html type
2.设置参数属性值
3.设置css样式
"""
示例:
from django import forms
from django.forms import fields
from django.forms import widgets class TestTorm(forms.Form):
user = fields.CharField(required=True,#必填
error_messages={"required":'不能为空!'},
label="用户名",
)
age = fields.IntegerField(required=True,
label="年龄",
error_messages={
"required":'不能为空!',
"min_value":"太小了",
'max_value':'太老了'
},
min_value=18,
max_value=50)
email = fields.EmailField(required=True,label="邮箱",error_messages={"required":'不能为空!'})
choice = [(1, 'A'), (2, 'B'), (3, 'C')]
aaa = fields.TypedChoiceField(choices=choice)
# 通过widget 自定制方式
aab = fields.CharField(widget=widgets.Select()) # 通过__init__ 实时获取数据库的数据 传递给前端页面
def __init__(self,*args,**kwargs):
from app01 import models
super(TestTorm,self).__init__(*args,**kwargs)
self.fields['aab'].widget.choices= models.Userinfo.objects.values_list('uid','uname') #实例化时,传递值
# obj = TestTorm('可以以字典方式设置默认值')
views 页面:(导入TestTorm,然后实例化,然后将实例传递至前端)
from django.shortcuts import render,HttpResponse
from app01.tests import TestTorm # Create your views here. def index(request):
if request.method == 'GET':
obj = TestTorm()
# obj = TestTorm('可以以字典方式设置默认值')
return render(request, 'index.html',{'obj':obj})
else:
obj = TestTorm(request.POST)
return render(request, 'index.html', {'obj': obj})
obj = TestTorm(request.POST) 获取前端提交的字段,验证是否符合,不符合即 错误字段提示
前端页面
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<title>Title</title>
</head>
<body>
<div>
{#不同的生成方式一#}
<form method="post" action="/index/" novalidate >
{#novalidate 不加载 #}
<li>{% csrf_token %}</li>
<p>{{ obj.user.label }}{{ obj.user }}{{ obj.errors.user.0 }}</p>
<p>{{ obj.age.label }}{{ obj.age }}{{ obj.errors.age.0 }}</p>
<p>{{ obj.email.label }}{{ obj.email }}{{ obj.errors.email.0 }}</p>
<p>{{ obj.aaa.label }}{{ obj.aaa }}{{ obj.errors.aaa.0 }}</p>
<p>{{ obj.aab.label }}{{ obj.aab }}{{ obj.errors.aab.0 }}</p>
<li><input type="submit" class="tijiao" value="提交"></li>
</form> {#不同的生成方式:二 生成整表#}
<form method="post" action="/index/" novalidate >
{{ obj.as_p }}
{#p标签形式#}
</form>
<form method="post" action="/index/" novalidate >
{{ obj.as_table }}
{#table标签形式#}
</form>
<form method="post" action="/index/" novalidate >
{{ obj.as_ul }}
{#ul标签形式#}
</form>
</div>
</body>
</html>
自定制
以上要不满足需求还可以自定制:
widget
1.自定义显示html type
2.设置参数属性值 attr={'class':'classname'}
3.设置css样式 attr={'study':'classname'}
# 先导入这个模块
from django.forms import widgets
# 参数 格式
自定义字段名 = fields.字段数据类型(widget=widgets.插件(参数:attr={'class':'classname'}))
choice = [(1, 'A'), (2, 'B'), (3, 'C')]
aab = fields.CharField(widget=widgets.Select(choices=choice))
数据过滤定制:(导入模块,定制规则和提示)
from django.core.validators import RegexValidator class TestTorm(forms.Form):
pwd = fields.CharField(
required=True,
label="密码",
error_messages={
"required": '不能为空!'},
widget=widgets.PasswordInput(attrs={ 'placeholder': "请输入密码"}),
validators=[RegexValidator(r"[0-9]+",'必须为数字'),
RegexValidator(r"^177", '必须为177开头')])
渲染问题
为什么Django传递至前端的 字符串能正常渲染成HTML标签,不是要加{{ | safe }} 才可以显示的吗?????
python 通过拼接字符串然后传递至前端页面渲染成HTML标签
前有学过在 {{text | safe }} 即可渲染
Django中可以:
from django.utils.safestring import mark_safe
text = mark_safe(text) 再传递至前端也可以达到效果
Django学习手册 - Form 插件的更多相关文章
- Django学习之Form表单
一.Form介绍 普通方式手写注册功能 使用form组件实现注册功能 二.Form那些事儿 1.常用字段与插件 initial error_messages password radioSelect ...
- django学习之- Form
参考:http://www.cnblogs.com/wupeiqi/articles/6144178.htmlFORM中的字段只对post上来的数据进行form验证,主要涉及:字段 和 插件字段:对用 ...
- Django学习手册 - 登录验证码
生成验证码函数 import random from PIL import Image, ImageDraw, ImageFont, ImageFilter _letter_cases = " ...
- Django学习手册 - ORM数据类型
DOM 字段/参数 配置格式: Module.字段(参数) 常用的字段归纳: 数字 models.AutoField() 自增列(int),必须设置为主键 models.IntegerField() ...
- Django学习手册 - 前端input数据获取
view获取数据方法归纳: #请求meta数据 request.mata(...) request.method(POST,GET,PUT) #从meta里面获取数据 request.path_inf ...
- Django学习手册 - cookie / session
cookie """ cookie属性: obj.set_cookie(key,value,....) obj.set_signed_cookie(key,value,s ...
- Django学习手册 - 正则URL路由配置/路由分发
############################################### 总结: 一.url路由配置: 方式一:(通过url链接get获取) 方式二:(url路由匹配方式获取-拓 ...
- Django 学习手册 - 下载数据库表格(XLS/CSV)
下载XLS表格方式: 前置: 需要安装xlwt模块 views : def export_users_xls(request): response = HttpResponse(content_typ ...
- Django学习手册 - 基于requests API验证(二)
原理分析: API接口验证 1.一个认证的key server端 和 client端都必须有这么一个认证key. 2.认证登录的时间限定 3.保存已验证的信息,在以后的验证不能再次登录 client ...
随机推荐
- TODO 动态执行appium代码,便于修改和调试
https://testerhome.com/topics/9040 还没尝试过. 不过不是很懂怎么实现的,java不是编译后再运行的语言吗?怎么一边编译一边运行呢???
- HTML学习笔记Day3
一.CSS样式 1.每个css样式都必须由两部分组成:选择符(Selector)+声明(Deleration) 注:声明又包括属性(Properyt)和属性值(value) 2.css属性:属性是指定 ...
- python中执行shell命令的几个方法小结
原文 http://www.jb51.net/article/55327.htm 最近有个需求就是页面上执行shell命令,第一想到的就是os.system, os.system('cat /proc ...
- Yearning 介绍(SQL审核平台)
介绍 Yearning SQL 审计平台 基于Vue.js与Django的整套mysql-sql审核平台解决方案.提供基于Inception的SQL检测及执行. GitHub:https://gith ...
- MySQL的复制机制
MySQL的复制机制 作者:尹正杰 版权声明:原创作品,谢绝转载!否则将追究法律责任. 一.MySQL复制介绍 1>.MySQL复制允许将主实例(master)上的数据同步到一个或多个从实例( ...
- python 列表 元祖 集合
#####################概念#######################1,什么是列表: 列表由[]表示,里面每一项元素用逗号隔开,里面什么都可以装.能装对象的对象. 列表可以装大 ...
- layui(四)——table组件常见用法总结
table是 layui 最核心的组成之一.它用于对表格进行一些列功能和动态化数据操作,涵盖了日常业务所涉及的几乎全部需求.支持固定表头.固定行.固定列左/列右,支持拖拽改变列宽度,支持排序,支持多级 ...
- HDU - 6304(2018 Multi-University Training Contest 1) Chiaki Sequence Revisited(数学+思维)
http://acm.hdu.edu.cn/showproblem.php?pid=6304 题意 给出一个数列的定义,a[1]=a[2]=1,a[n]=a[n-a[n-1]]+a[n-1-a[n-2 ...
- Spark源码剖析 - SparkContext的初始化(九)_启动测量系统MetricsSystem
9. 启动测量系统MetricsSystem MetricsSystem使用codahale提供的第三方测量仓库Metrics.MetricsSystem中有三个概念: Instance:指定了谁在使 ...
- NLP里面的一些基本概念
1,corpus 语料库 a computer-readable collection of text or speech 2,utterance 发音 比如下面一句话:I do uh main- m ...