Django之forms组件使用
注册功能
1.渲染前端标签获取用户输入 >>> 渲染标签
2.获取用户输入传递到后端校验 >>> 校验数据
3.校验未通过展示错误信息 >>> 展示信息 校验数据(前后端都可以校验)
校验前端后端都可以做,但是前端可以不做,后端必须得做!!! django form组件
1.渲染标签
2.校验数据
3.展示信息 校验数据
第一步需要在views中写一个form类
from django import forms class MyForm(forms.Form):
name = forms.CharField(max_length=6)
password = forms.CharField(max_length=8,min_length=3)
email = forms.EmailField(required=True)
第二步实例化form对象
form_obj = MyForm({'name':'jason'}) 第三步查看数据校验是否合法
form_obj.is_valid() # 只有当所有的字段都校验通过才会返回True 第四步查看校验错误的信息
form_obj.errors # 这个里面放的是所有校验未通过的字段及错误提示
"""
{
'name': ['Ensure this value has at most 6 characters (it has 7).'],
'password': ['Ensure this value has at least 3 characters (it has 2).'],
'email': ['Enter a valid email address.']
} """
第五步查看校验通过的数据
form_obj.cleaned_data # 符合校验规则数据都会被放到该对象中
ps:form组件校验数据的规则从上往下依次取值校验
校验通过的放到cleaned_data
校验失败的放到errors
注意:
form中所有的字段默认都是必须传值的(required=True)
校验数据的时候可以都传(多传的数据不会做任何的校验>>>不会影响form校验规则) 渲染标签
form组件只帮你渲染获取用户输入的标签,不会帮你渲染提交按钮,需要手动添加
<h1>第一种渲染方式(可扩展性较差)</h1>
{{ form_obj.as_p }}
{{ form_obj.as_ul }} <h1>第二种渲染方式</h1>
<form action="">
<p>{{ form_obj.name.label }}{{ form_obj.name }}</p>
<p>{{ form_obj.password.label }}{{ form_obj.password }}</p>
<p>{{ form_obj.email.label }}{{ form_obj.email }}</p>
<input type="submit">
</form> <h1>第三种渲染标签的方式</h1>
<form action="">
{% for foo in form_obj %}
<p>{{ foo.label }}{{ foo }}</p>
{% endfor %}
</form> 前端取消校验 参数 novalidate
<form action="" method="post" novalidate>
</form> form组件提交数据如果数据不合法,页面上会保留之前用户输入的信息
在使用form组件对模型表进行数据校验的时候,只需要保证字段一致
那么在创建的对象的时候你就直接**form_obj.cleaned_data <form action="" method="post" novalidate>
{% for foo in form_obj %}
<p>
{{ foo.label }}{{ foo }}
<span>{{ foo.errors.0 }}</span>
</p>
{% endfor %}
<input type="submit">
</form> # 钩子函数
# 局部钩子函数 (单个字段的校验利用局部钩子函数)
def clean_name(self):
name = self.cleaned_data.get('name')
if '' in name:
self.add_error('name','光喊666是不行的,要有真实力!')
return name # return还是要加上的,兼容性考虑 # 全局钩子函数 (多个字段的校验利用全局钩子函数)
def clean(self):
password = self.cleaned_data.get('password')
confirm_password = self.cleaned_data.get('confirm_password')
if not password == confirm_password:
self.add_error('confirm_password',"两次密码不一致,你这个dsb!")
return self.cleaned_data # 设置标签样式
from django import forms
from django.forms import widgets
password = forms.CharField(max_length=8,min_length=3,error_messages={
'max_length': '密码最长8位',
'required': '密码不能为空',
'min_length':'密码最少3位'
},widget=widgets.PasswordInput(attrs={'class':'c1 form-control'})) hobby = forms.ChoiceField(
choices=((1, "篮球"), (2, "足球"), (3, "双色球"),),
label="爱好",
initial=3,
widget=forms.widgets.Select()
)
hobby1 = forms.MultipleChoiceField(
choices=((1, "篮球"), (2, "足球"), (3, "双色球"),),
label="爱好",
initial=[1, 3],
widget=forms.widgets.SelectMultiple()
) keep = forms.ChoiceField(
label="是否记住密码",
initial="checked",
widget=forms.widgets.CheckboxInput()
)
forms组件使用完整示例:
views中定义form类:
class RegForm(forms.Form):
name = forms.CharField(max_length=10,min_length=3,label='用户名', error_messages={
'required':'用户名不能为空!',
'invalid':'格式错误!',
'max_length':'注册用户名长度不能超过10位!',
'min_length':'注册用户名长度不能低于3位',
},
widget=forms.widgets.Input(attrs={'class':'form-control','style':'width:250px'},))
password = forms.CharField(max_length=16,min_length=3,label='密码', error_messages={
'required':'注册密码不能为空!',
'invalid':'格式错误!',
'max_length':'密码超出最大长度16位!',
'min_length':'密码长度不能低于3位!'
},
widget=forms.widgets.PasswordInput(attrs={'class':'form-control','style':'width:250px'})
)
re_password = forms.CharField(max_length=16, min_length=3,label='再次输入密码', error_messages={
'required': '注册密码不能为空!',
'invalid': '格式错误!',
'max_length': '密码超出最大长度16位!',
'min_length': '密码长度不能低于3位!'
},
widget=forms.widgets.PasswordInput(
attrs={'class': 'form-control', 'style': 'width:250px'})
)
cellphone = forms.CharField(max_length=14,min_length=10,label='请输入手机号',error_messages={
'required': '注册手机号不能为空!',
'invalid': '格式错误!',
'max_length': '手机号长度不合法!',
'min_length': '手机号长度不合法!'
},
widget=forms.widgets.Input(attrs={'class':'form-control','style':'width:250px','id':'cellphone'})
)
def clean_name(self):
name = self.cleaned_data.get("name")
if not name.isalpha():
self.add_error('name','用户名必须由字母数字组成!')
elif name[0].isdigit():
self.add_error('name','用户名不能以数字开头!')
elif models.User.objects.filter(name=name):
self.add_error('name','该用户名已存在!')
return name def clean(self):
password = self.cleaned_data.get("password")
re_password = self.cleaned_data.get('re_password')
if password != re_password:
self.add_error('re_password','两次密码不一致!')
elif password == '':
self.add_error('password','当前密码过于简单!')
return self.cleaned_data
def clean_cellphone(self):
cellphone = self.cleaned_data.get("cellphone")
regExp = "^((13[0-9])|(15[^4])|(18[0,2,3,5-9])|(17[0-8])|(147))\\d{8}$"
if not re.findall(regExp,cellphone):
self.add_error('cellphone','请输入正确的手机号!')
elif models.User.objects.filter(cellphone = cellphone):
self.add_error('cellphone','该手机号已注册!请换一个再试!')
return cellphone
前端渲染代码:
由于引入了许多第三方样式,没有导入JS,CSS样式等部分,截取了body部分作为示例
<body>
<div class="container" id="particles-js">
<div id="main-div">
<h3 style="text-align: center">欢迎注册图书管理系统</h3>
<form action="" method="post" style="width: 250px;margin: 20px auto" autocomplete="off" novalidate>
{% for form_datum in form_data %}
<p>{{ form_datum.label }}{{ form_datum }}
<span style="color: red">{{ form_datum.errors.0 }}</span>
</p>
{% endfor %} <span>请输入验证码:</span>
<p >
<input type="text" class="form-control" name="yzm" style="width: 120px;display:inline-block;">
<input href="#" class="btn btn-info feachBtn" style="width: 130px;float: right;" value="获取手机验证码">
</p>
<span style="color: red">{{ yzm }}</span>
<p style="padding: 10px 0;"><input type="submit" class="btn btn-info btn-block" value="注册"></p> </form>
</div>
</div>
</body>
views视图函数处理部分:
def register(request): form_data = RegForm()
if request.method == "POST":
form_data = RegForm(request.POST)
if form_data.is_valid(): #检查是否通过校验,没有则返回前端error信息,通过则注册
dic = dict(form_data.cleaned_data)
dic["user_type"] = 'user'
dic.pop('re_password')
# dic['cellphone'] = request.session.get("cellphone")
models.User.objects.create(**dic)
return redirect('/admins/show-book/')
return render(request, "reg.html",locals())
Django之forms组件使用的更多相关文章
- django之forms组件
在django中forms组件有其强大的功能,里面集合和众多的函数和方法:下面来看一下它的源码 """ Form classes """ f ...
- web框架开发-Django的Forms组件
校验字段功能 针对一个实例:用户注册. 模型:models.py class UserInfo(models.Model): name=models.CharField(max_length=32) ...
- Django之forms组件进阶
Django Form表单组件 Form介绍 我们之前在HTML页面中利用form表单向后端提交数据时,都会写一些获取用户输入的标签并且用form标签把它们包起来. 与此同时我们在好多场景下都需要 ...
- django之forms组件,cookie&session
forms组件 先自己实现注册功能,并且对用户输入的信息加限制条件如果用户输入的信息不符合条件,前端展示报错信息 from django.shortcuts import render,HttpRes ...
- Django学习之八:forms组件【对form舒心了】
目录 Django forms组件 bound and unbound form instance forms渲染有关 隐藏一个字段,不渲染它 form 校验 form类 ModelForm 利用Mo ...
- Django组件-Forms组件
Django的Forms组件主要有以下几大功能: 页面初始化,生成HTML标签 校验用户数据(显示错误信息) HTML Form提交保留上次提交数据 一.小试牛刀 1.定义Form类 from dja ...
- django的forms认证组件
django的forms认证组件 每个网站的注册界面都需要有相应的"认证"功能,比如说认证注册页面的用户名是否已被注册,二次输入的密码是否一致以及认证用户输入的用户名.邮箱.手机号 ...
- 08 Django组件-Forms组件
Django的Forms组件主要有以下几大功能: 页面初始化,生成HTML标签 校验用户数据(显示错误信息) HTML Form提交保留上次提交数据 一.小试牛刀 1.定义Form类 from dja ...
- Django组件--forms组件(注册用)
一.forms组件--校验类的使用 二.form组件--校验类的参数 三.forms组件校验的局部钩子--自定义校验规则(要看源码理解) 四.forms组件校验的全局钩子--校验form表单两次密码输 ...
随机推荐
- Codeforces 385 D Bear and Floodlight
主题链接~~> 做题情绪:时候最后有点蛋疼了,处理点的坐标处理晕了.so~比赛完清醒了一下就AC了. 解题思路: 状态压缩DP ,仅仅有 20 个点.假设安排灯的时候仅仅有顺序不同的问题.全然能 ...
- onload 事件
定义和用法 onload 事件会在页面或图像加载完成后立即发生. 语法 onload="SomeJavaScriptCode" 参数 描述 SomeJavaScriptCode 必 ...
- day68_淘淘商城项目_01_电商介绍 + 互联网术语 + SOA + 分布式 + 集群介绍 + 环境配置 + 框架搭建_匠心笔记
课程计划 第一天: 1.电商行业的背景介绍--电子商务 2.淘淘商城的系统架构 a) 功能介绍 b) 架构讲解 3.工程搭建--后台工程 a) 使用maven搭建工程(工程大) b) 使用maven的 ...
- vim for windows download and installation
这是vim皇冠vim简要 ------------------------------------------------- WHAT IS VIM Vim is an almost compatib ...
- poj 1125 Stockbroker Grapevine(多源最短)
id=1125">链接:poj 1125 题意:输入n个经纪人,以及他们之间传播谣言所需的时间, 问从哪个人開始传播使得全部人知道所需时间最少.这个最少时间是多少 分析:由于谣言传播是 ...
- XP双网卡不能上网的问题
转载. 现在很多本本都是双网卡配置,让两个网卡分别负责连接内外网能够加快上网速度和连接稳定,但不少网友照做后会出现无法上网的情况,这是由于默认网关冲突所导致的.那么该如何处理让双网卡各行其是,互不干扰 ...
- JSON的一些要点总结 专题
JavaScript Object Notation CSRF (pronounced sea-surf) 字面量(literal):字符串的意思和要表达的意思是一致的 JSON 是一种数据交换格式( ...
- SSM导出报表为csv文件
报表导出思路为,在后台用iDataReader将查询得到的数据写进文件并压缩,向前端返回文件位置的链接,在前端执行下载操作. web端: 1. ajax请求url,将返回的路径json字符串解析并执行 ...
- WPF中ListBox滚动时的缓动效果
原文:WPF中ListBox滚动时的缓动效果 上周工作中遇到的问题: 常规的ListBox在滚动时总是一格格的移动,感觉上很生硬. 所以想要实现类似Flash中的那种缓动的效果,使ListBox滚动时 ...
- 【 D3.js 入门系列 --- 6 】 如何使移动图表
我的个人博客是: www.ourd3js.com csdn博客为: blog.csdn.net/lzhlzz 转载请注明出处,谢谢. [5.1]节中制作了一个比較完好的图表.但它是静态的.想做出它的动 ...