【django之form表单】
一、构建一个表单
假设你想在你的网站上创建一个简单的表单,以获得用户的名字。你需要类似这样的模板:
<form action="/your-name/" method="post">
<label for="your_name">Your name: </label>
<input id="your_name" type="text" name="your_name">
<input type="submit" value="OK">
</form>
这是一个非常简单的表单。实际应用中,一个表单可能包含几十上百个字段,其中大部分需要预填充,而且我们预料到用户将来回编辑-提交几次才能完成操作。
我们可能需要在表单提交之前,在浏览器端作一些验证。我们可能想使用非常复杂的字段,以允许用户做类似从日历中挑选日期这样的事情,等等。
这个时候,让Django 来为我们完成大部分工作是很容易的。
Form表单的功能
- 自动生成HTML表单元素
- 检查表单数据的合法性
- 如果验证错误,重新显示表单(数据不会重置)
- 数据类型转换(字符类型的数据转换成相应的Python类型)
二、在Django 中构建一个表单
1、Form 类
创建form组件
from django import forms
from django.forms import widgets
from django.core.exceptions import NON_FIELD_ERRORS, ValidationError
class LoginForm(forms.Form):
user=forms.CharField(label="用户名",min_length=3,max_length=8,
widget=widgets.TextInput(attrs={"class": "form-control"}),
error_messages={"min_length":"太短","required":"必填"}) pwd=forms.CharField(label="密码",min_length=5,
widget=widgets.PasswordInput(attrs={"class":"form-control"}),
error_messages={"min_length":"太短", "required": "必填"}
)
2、views.py
如果访问视图的是一个GET 请求,它将创建一个空的表单实例并将它放置到要渲染的模板的上下文中。这是我们在第一个访问该URL 时预期发生的情况。
如果表单的提交使用POST 请求,那么视图将再次创建一个表单实例并使用请求中的数据填充它:form = NameForm(request.POST)。这叫做”绑定数据至表单“(它现在是一个绑定的表单)。
我们调用表单的is_valid()方法;如果它不为True,我们将带着这个表单返回到模板。这时表单不再为空(未绑定),所以HTML 表单将用之前提交的数据填充,然后可以根据要求编辑并改正它。
如果is_valid()为True,我们将能够在cleaned_data 属性中找到所有合法的表单数据。在发送HTTP 重定向给浏览器告诉它下一步的去向之前,我们可以用这个数据来更新数据库或者做其它处理。
if GET请求
if GET请求:
login_form=LoginForm()
return render(request,"login_form.html",locals()) 渲染方式:
(1) login_form.as_p (2) 推荐
<form action="" method="post" novalidate>
{% csrf_token %}
<div class="form-group">
<label for="">{{ login_form.user.label }}</label>
{{ login_form.user }} <span>{{ login_form.errors.user.0 }}</span>
</div>
<div class="form-group">
<label for="">{{ login_form.pwd.label }}</label>
{{ login_form.pwd }} <span>{{ login_form.errors.pwd.0 }}</span>
</div>
<input type="submit">
</form>
if POST 请求
if POST 请求:
login_form=LoginForm(request.POST)
if login_form.is_valid():
# 所有字段验证成功
# 所有请求数据:login_form.cleaned_data
else:
#login_form.errors # 字典:{"user":["","",]}
#login_form.errors.get("user") # 列表:["",""]
return render(request, "login_form.html", locals())
渲染:
<form action="" method="post" novalidate>
{% csrf_token %}
<div class="form-group">
<label for="">{{ login_form.user.label }}</label>
{{ login_form.user }} <span>{{ login_form.errors.user.0 }}</span>
</div>
<div class="form-group">
<label for="">{{ login_form.pwd.label }}</label>
{{ login_form.pwd }} <span>{{ login_form.errors.pwd.0 }}</span>
</div>
<input type="submit">
</form>
is_valid()
Form 的实例具有一个is_valid() 方法,它为所有的字段运行验证的程序。当调用这个方法时,如果所有的字段都包含合法的数据,它将:
- 返回
True - 将表单的数据放到
cleaned_data属性中。
is_valid:
self.errors={}
self.cleaned_data={}
for name ,field in self.fields.items():
if field(数据):
self.cleaned_data[name]="数据"
else:
self.errors[name]="错误信息"
钩子函数
def clean_user(self):
val=self.cleaned_data.get("user") import re
# if not UserInfo.objects.filter(username=val):
# return val
# else:
# raise ValidationError("") if not val.isdigit():
return val
else:
raise ValidationError("用户名不能是纯数字!") def clean_pwd(self):
val=self.cleaned_data.get("pwd") if val.startswith("yuan"):
return val
else:
raise ValidationError("没有yuan开头")
代码
from django.shortcuts import render,HttpResponse # Create your views here. from django import forms
from django.forms import widgets
from django.core.exceptions import NON_FIELD_ERRORS, ValidationError
class LoginForm(forms.Form):
user=forms.CharField(label="用户名",min_length=3,max_length=8,
widget=widgets.TextInput(attrs={"class": "form-control"}),
error_messages={"min_length":"太短","required":"必填"}) pwd=forms.CharField(label="密码",min_length=5,
widget=widgets.PasswordInput(attrs={"class":"form-control"}),
error_messages={"min_length":"太短", "required": "必填"}
) def clean_user(self):
val=self.cleaned_data.get("user") import re
# if not UserInfo.objects.filter(username=val):
# return val
# else:
# raise ValidationError("") if not val.isdigit():
return val
else:
raise ValidationError("用户名不能是纯数字!") def clean_pwd(self):
val=self.cleaned_data.get("pwd") if val.startswith("yuan"):
return val
else:
raise ValidationError("没有yuan开头") # email=forms.EmailField()
# age=forms.IntegerField() def login(request):
if request.method=="POST": login_form=LoginForm(request.POST)
if login_form.is_valid():
print(login_form.cleaned_data) # {"user":"","pwd":123}
return HttpResponse("OK")
else:
# print(login_form.cleaned_data)# {"pwd":123456}
# print(type(login_form.errors)) # {"user":["","",]}
# print(type(login_form.errors.get("user"))) # {"user":"....."}
return render(request, "login_form.html", locals()) login_form=LoginForm()
return render(request,"login_form.html",locals())
views.py
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<title>Title</title>
<!-- 最新版本的 Bootstrap 核心 CSS 文件 -->
<link rel="stylesheet" href="https://cdn.bootcss.com/bootstrap/3.3.7/css/bootstrap.min.css"
integrity="sha384-BVYiiSIFeK1dGmJRAkycuHAHRg32OmUcww7on3RYdg4Va+PmSTsz/K68vbdEjh4u" crossorigin="anonymous">
</head>
<body> {#<form action="" method="post" novalidate>#}
{# {% csrf_token %}#}
{# {{ login_form.as_p }}#}
{# <input type="submit">#}
{#</form>#} <hr> <div class="container">
<div class="row">
<div class="col-md-5">
<form action="" method="post" novalidate>
{% csrf_token %}
<div class="form-group">
<label for="">{{ login_form.user.label }}</label>
{{ login_form.user }} <span>{{ login_form.errors.user.0 }}</span>
</div>
<div class="form-group">
<label for="">{{ login_form.pwd.label }}</label>
{{ login_form.pwd }} <span>{{ login_form.errors.pwd.0 }}</span>
</div>
<input type="submit">
</form>
</div>
</div>
</div> </body>
</html>
login_form.html
【django之form表单】的更多相关文章
- Django的form表单
html的form表单 django中,前端如果要提交一些数据到views里面去,需要用到 html里面的form表单. 例如: # form2/urls.py from django.contrib ...
- Django 11 form表单(状态保持session、form表单及注册实现)
Django 11 form表单(状态保持session.form表单及注册实现) 一.状态保持 session 状态保持 #1.http协议是无状态的:每次请求都是一次新的请求,不会记得之前通信的状 ...
- 转载:Django之form表单
转载: 一.使用form类创建一个表单 先定义好一个RegForm类: forms.py from django import forms # 导入forms类 class NameForm(form ...
- Django--分页器(paginator)、Django的用户认证、Django的FORM表单
分页器(paginator) >>> from django.core.paginator import Paginator >>> objects = ['joh ...
- django之form表单验证
django中的Form一般有两种功能: 输入html 验证用户输入 #!/usr/bin/env python # -*- coding:utf- -*- import re from django ...
- django中form表单的提交:
一,关于表单: 表单在百度百科的解释: 表单在网页中主要负责数据采集功能.一个表单有三个基本组成部分: 表单标签:这里面包含了处理表单数据所用CGI程序的URL以及数据提交到服务器的方法. 表单域 ...
- Day19 Django之Form表单验证、CSRF、Cookie、Session和Model操作
一.Form表单验证 用于做用户提交数据的验证1.自定义规则 a.自定义规则(类,字段名==html中的name值)b.数据提交-规则进行匹配代码如下: """day19 ...
- Django的form表单之文件上传
在生成input标签的时候可以指定input标签的类型为file类型 <!DOCTYPE html> <html lang="en"> <head&g ...
- Django 提交 form 表单(使用sqlite3保存数据)
优化 提交 form 表单,https://www.cnblogs.com/klvchen/p/10608143.html 创建数据库的字段,在 models.py 中添加 from django.d ...
随机推荐
- 开发中使用UEditor编辑器的注意事项
最近在一个刚结束的一个项目中使用到了UEditor编辑器,下面总结一下遇到的问题以及使用时需要注意的地方: 1. 使用UEditor插件需要先对其进行路径配置: 在ueditor.config.js文 ...
- bzoj:3400 [Usaco2009 Mar]Cow Frisbee Team 奶牛沙盘队
Description 农夫顿因开始玩飞盘之后,约翰也打算让奶牛们享受飞盘的乐趣.他要组建一只奶牛飞盘 队.他的N(1≤N≤2000)只奶牛,每只部有一个飞盘水准指数Ri(1≤Ri≤10000 ...
- [UWP]使用Reveal
1. 前言 之前在 如何使用Fluent Design System 这篇文章里已经简单介绍过Reveal的用法,这篇再详细介绍其它内容. 2. 自定义RevealButtonStyle 我觉得常用I ...
- [国嵌攻略][164][USB驱动程序设计]
USB驱动模型 1.USB host controller driver(主控器驱动):为USB主控制器提供驱动程序 2.USB core(USB核心):连接USB主控制器驱动和USB设备驱动 3.U ...
- html日历(1)
<html> <head> <link rel="stylesheet" type="text/css" href="S ...
- API接口签名验证2
http://www.jianshu.com/p/d47da77b6419 系统从外部获取数据时,通常采用API接口调用的方式来实现.请求方和�接口提供方之间的通信过程,有这几个问题需要考虑: 1.请 ...
- vue 路由部署服务器子目录问题
http://blog.csdn.net/hero82748274/article/details/73436497 <Egret 引擎入门> 这两天一直在查询vue经过打包后部署服务器一 ...
- 阿里巴巴Java开发手册评
2016年底的时候阿里巴巴公开了其在内部使用的Java编程规范.随后进行了几次版本修订,目前的版本为v1.0.2版.下载地址可以在其官方社区-云栖社区https://yq.aliyun.com/art ...
- 【开发技术】eclipse中格式化代码快捷键Ctrl+Shift+F失效的解决办法
要格式化代码的时候,右键-source-format能够起效,但ctrl+shift+f不好使了. 原来是和“简繁体快捷键”冲突了.输入法中的这个快捷键我们一般不用,小勾勾去掉就成了. eclipse ...
- Hadoop问题:The auxService:mapreduce_shuffle does not exist
问题描述:The auxService:mapreduce_shuffle does not exist INFO mapreduce.Job: Task Id : attempt_146180833 ...