1.引入案例

  • 实现注册功能

    • 用户名不能含有"卧槽",如果用户输入,就提示输入内容不合法
    • 密码至少有6位,否则提示密码太短
  • 说明

    • 通常前后端都会校验数据
    • 前端校验可以没有,但后端校验必须有

2. form组件的功能

  • 渲染页面:搭建前端页面
  • 校验数据:获取前端用户提交的数据校验
  • 展示错误信息:将数据的校验结果返回到前端展示给用户

3. form组件的使用

3.1 自定义form校验类

# views.py
from django import forms class MyForm(forms.Form):
username = forms.CharField(min_length=4, max_length=16)
password = forms.CharField(min_length=6, max_length=16)
email = forms.EmailField()

3.2 校验数据

  • 校验数据合法性
from app01 import views

# 将要校验的数据以字典的形式传给自定义的类
obj = views.MyForm({'username': 'qwer', 'password': '1234','email': 'ema'}) # 判断数据是否合法
print(obj.is_vaild()) # 所有数据都负荷要求才返回True # 查看符合校验条件的数据
print(obj.clean_data) # 此处username符合 # 查看不符合校验条件的数据
print(obj.errors)
# 此处password与email不符合,结果如下
{
'password':['Ensure this value has at least 6 characters (it has 4).'],
'email': ['Enter a valid email address.']
}
  • 校验数据时多传或少传值的情况
from app01 import views

# 少传值的情况
obj = views.MyForm({'username': 'qwer', 'password': '123456'})
print(obj.is_vaild) # False
print(obj.errors) # {'email': ['This field is required.']} # 多传值的情况
obj = views.MyForm({'username': 'qwer', 'password': '123456', 'email': 'qwer@qq.com', 'abc': '123'})
print(obj.is_vaild) # True
  • 说明

    默认情况下,可以多传值,但绝对不能少传

3.3 渲染页面

  • forms组件只会渲染获取用户输入的标签,提交按钮需要自己手动写
  • 三种渲染前端页面的方式
{# 第一种:封装程度太高,标签参数不方便调整,可扩展性差(不推荐) #}
{{ form_obj.as_p }}
{{ form_obj.as_ul }} {# 第二种:可扩展性高,但手写的代码较多,不推荐 #}
<p>
{{ form_obj.username.label }}{{ form_obj.username }}
</p>
<p>
{{ form_obj.password.label }}{{ form_obj.password }}
</p>
<p>
{{ form_obj.email.label }}{{ form_obj.email }}
</p> {# 第三种:可拓展性高,代码简洁,推荐使用 #}
{% for foo in for_obj %}
<p>
{{ foo.label }}{{ foo }}
</p>
{% endfor %}

3.4 展示错误信息

  • 取消前端校验的方法
{# 如果我们使用了form组件,前端就会帮我们做校验,但是我们不想使用前端校验 #}
{# 在for标签中添加novaildate #}
<form action='' method='post' novalidate></form>
  • 展示错误信息
{# 对象.errors.0 #}
<form action='' method='post' novalidate>
{% for foo in form_obj %}
<p>
{{ foo.label }}{{ foo }}
<span style='color:red'>{{ foo.errors.0 }}</span>
</p>
{% endfor %} <input type='submit'>
</form>

3.5 自定义校验结果

  • 修改错误信息,在error_messages中

    • 输入为空错误信息:required
    • 邮箱格式错误信息:invalid
  • 修改label名:label='用户名'
  • 设置初始值:initial='初始值'
  • 此项可以为空:required=False
from django import forms

class MyForm(forms.Form):
username = forms.CharField(min_length=4, max_length=16, label='用户名',
error_messages={
'min_length': '用户名最短4位',
'max_length': '用户名最多16位',
'required': '用户名不能为空',
},
initial='初始值'
)
password = forms.CharField(min_length=6, max_length=16, label='密码',
error_messages={
'min_length': '密码最短6位'.
'max_length': '密码最多16位',
'required': '密码不能为空'
})
email =forms.EmailField(label='邮箱',
error_messages={
'invalid': '邮箱格式不正确'
}, required=False)

3.6 forms组件钩子函数

针对字段,通过钩子函数还可以做额外的校验

  • 局部钩子函数

    对单个字段进行额外的校验,使用局部钩子函数

class MyForm(forms.Form):
# .... def clean_username(self):
username = self.clean_data.get('username')
if '卧槽' in username:
# 给username字段添加错误信息
self.add_error('username': '小孩子不可以讲脏话哦')
return username
  • 全局钩子函数

    校验多个字段,使用全局钩子,例如

class MyForm(forms.Form):
# .... def clean(self):
password = self.clean_data.get('password')
re_password = self.clean_data.get('re_password')
if not password == re_password:
self.add_error('re_password', '两次密码不一致')
return self.clean_data

3.7 对字段进行正则校验

from django import forms
from django.core.validators import RegexValidator class MyForm(forms.Form):
# ....
phone = forms.CharField(
validators=[RegexValidator(r'^[0-9]+$', '请输入数字'),
Regexvalidator(r'^159[0-9]+$', '号码必须以159开头')]
)

3.8 改变input框的type属性值

# 改变input框type属性的方法
widget = widgets.TextInput() # 普通文本
widget = widgets.PaddwordInput() # 密码 # 让forms组件渲染出来的input框有form-control类属性
# 如果有多个类,用空格隔开
widget = widgets.TextInput(attrs={'class': 'form-control others'})
widget = widgets.PasswordInput(attrs={'class': 'form-control others'})

Dango之form校验组件的更多相关文章

  1. django之分页器、多对多关系、form校验组件

    批量插入数据 bulk_create # 1.往书籍表中插入数据 1000 # for i in range(1000): # 这种插入方式 效率极低 # models.Book.objects.cr ...

  2. Django中的分页操作、form校验工具

    批量插入数据 后端: def fenye(request): book_list=[] for i in range(100): book_list.append(models.Book(title= ...

  3. 利用jquery.validate以及bootstrap的tooltip开发气泡式的表单校验组件

    表单校验是页面开发中非常常见的一类需求,相信每个前端开发人员都有这方面的经验.网上有很多成熟的表单校验框架,虽然按照它们默认的设计,用起来没有多大的问题,但是在实际工作中,表单校验有可能有比较复杂的个 ...

  4. 《React后台管理系统实战 :一》:目录结构、引入antd、引入路由、写login页面、使用antd的form登录组件、form前台验证、高阶函数/组件

    实战 上接,笔记:https://blog.csdn.net/u010132177/article/details/104150177 https://gitee.com/pasaulis/react ...

  5. 98.Ext.form.Label组件的基本用法

    转自:https://www.cnblogs.com/kelly/archive/2009/06/05/1496897.html 本篇介绍Ext.form.Label组件的基本用法: 这里通过上一篇介 ...

  6. 【共享单车】—— React后台管理系统开发手记:AntD Form基础组件

    前言:以下内容基于React全家桶+AntD实战课程的学习实践过程记录.最终成果github地址:https://github.com/66Web/react-antd-manager,欢迎star. ...

  7. 表单校验组件ValidForm

    10.1使用入门 1.引入css 请查看下载文件中的style.css,把里面Validform必须部分复制到你的css中 (文件里这个注释 "/*==========以下部分是Validf ...

  8. Vue2.0表单校验组件vee-validate的使用

    vee-validate使用教程 *本文适合有一定Vue2.0基础的同学参考,根据项目的实际情况来使用,关于Vue的使用不做多余解释.本人也是一边学习一边使用,如果错误之处敬请批评指出* 一.安装 n ...

  9. jQuery.validate 的form校验

    jQuery验证框架 : 基本html代码: <script src="js/jquery-1.9.1.js"></script> <script s ...

随机推荐

  1. PCB板HDI板几阶是什么意思

    http://blog.sina.com.cn/s/blog_55ff6d5d0102xxvx.html

  2. 零基础玩转C语言单链表

    下图为最一简单链表的示意图: 第 0 个结点称为头结点,它存放有第一个结点的首地址,它没有数据,只是一个指针变量.以下的每个结点都分为两个域,一个是数据域,存放各种实际的数据,如学号 num,姓名 n ...

  3. 万维网www与HTTP协议

    文章转自:https://blog.csdn.net/weixin_43914604/article/details/105901440 学习课程:<2019王道考研计算机网络> 学习目的 ...

  4. 查找最小生成树:普里姆算法算法(Prim)算法

    一.算法介绍 普里姆算法(Prim's algorithm),图论中的一种算法,可在加权连通图里搜索最小生成树.意即由此算法搜索到的边子集所构成的树中,不但包括了连通图里的所有顶点,且其所有边的权值之 ...

  5. Luogu P1297 [国家集训队]单选错位 | 概率与期望

    题目链接 题解: 单独考虑每一道题目对答案的贡献. 设$g_i$表示gx在第$i$道题目的答案是否正确(1表示正确,0表示不正确),则$P(g_i=1)$表示gx在第$i$道题目的答案正确的概率. 我 ...

  6. cf17B Hierarchy(额,,,水)

    题意: Nick's company employed n people. Now Nick needs to build a tree hierarchy of «supervisor-surbod ...

  7. TTMS 一个基于Java Swing的Socket通信的剧院票务管理系统

    TTMS (Theater Ticket Management System) 点我进入github TTMS全称剧院票务管理系统,分为客户端和服务器端.服务器端可以接收客户端连接请求,客户端相当于我 ...

  8. Jmeter二次开发实现自定义functions函数(九)

    在Jmeter->选项->函数助手对话框中我们可以看到Jmeter内置的一些常用函数,但考虑到测试过程中的实际情况,我们经常需要在脚本引用或者实现自定义的函数.那么如何在"函数助 ...

  9. C++ 函数模板和函数重载同时出现如何调用

    C++ 函数模板和函数重载同时出现如何调用 重点 函数模板不允许自动转换,普通函数可以进行自动类型转换 函数模板可以像普通函数一样被重载 C++编译器优先考虑调用普通函数 如果函数模板可以产生一个更好 ...

  10. 【Docker】Asp.net core在docker容器中的端口问题

    还记得[One by one系列]一步步学习docker(三)--实战部署dotnetcore中遇到的问题么?容器内部启动始终是80端口,并不由命令左右. docker run --name cont ...