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表单两次密码输 ...
随机推荐
- Verilog分频器
verilog设计进阶 时间:2014年5月6日星期二 主要收获: 1.自己动手写了第一个verilog程序. 题目: 利用10M的时钟,设计一个单周期形状例如以下的周期波形. 思考: 最開始的想法是 ...
- servlet-显示器
1.什么是监听器 监听器是实现一个特定的接口java规划,该计划的目的是还调用类方法监听器.java的awt大量使用该模式,如的能力button点击事件.当鼠标点击时,就会调用事件处理程序.又如:在j ...
- WPF中使用AxisAngleRotation3D实现CAD的2D旋转功能
原文:WPF中使用AxisAngleRotation3D实现CAD的2D旋转功能 对于CAD图形来说,3D旋转比较常用,具体实现方法在上篇文章<WPF中3D旋转的实现 >中做了 ...
- Mac版Visual Studio预览版
来了,Mac版Visual Studio预览版开放下载 投递人 itwriter 发布于 2016-11-17 12:11 评论(7) 有1317人阅读 原文链接 [收藏] « » 微软前俩天宣布,推 ...
- 【甘道夫】基于Mahout0.9+CDH5.2执行分布式ItemCF推荐算法
环境: hadoop-2.5.0-cdh5.2.0 mahout-0.9-cdh5.2.0 引言 尽管Mahout已经宣布不再继续基于Mapreduce开发,迁移到Spark.可是实际面临的情况是公司 ...
- 使用 Capistrano 和写作 Ruby 迭代边缘部署
想边自己写ruby代码,边部署随时能够到处查看,heroku域名又不友好,速度在国内又慢.于是乎想起来capistrano,于是学起 ... capistrano 一点入门认知 https://www ...
- Windows静态库和动态库的创建和使用(VS2005)
偶们在实际的编程开发中,经常会遇到运行时无法找到某个DLL文件或者链接时无法找到某个LIB文件.然后,我们就开始乱GOOGLE一下,然后将VS2005的设置改变一下,或许就Ok了,我们将别人开发的DL ...
- JS正则--非负整数或小数[小数最多精确到小数点后两位]
function ValidPrice(obj) { s = obj.value; //var reg = /^[0-9]*\.[0-9]{0,2}$/; var reg = /^[0-9]+([.] ...
- WPF 跨界面调用程序
this.Dispatcher.BeginInvoke(DispatcherPriority.Normal, (System.Threading.ThreadStart)delegate() { sE ...
- WPF 集合分组排序
<Window x:Class="ViewExam.MainWindow" xmlns="http://schemas.microsoft.com/w ...