目录

  1)django form作用

  2)django form使用

 

一:django form 作用

  django form有两个作用:一是用户输入数据验证;二是生成html

  1)用户输入数据验证,比如用户输入的用户名密码,不能为空,邮件格式验证等。如果自己写正则写很复杂。可以使用django form实现验证

  2)通过django form生成html表单

二:django form使用

  1)form常用方法 

    #表单使用
    obj=FM(request.POST) #把POST信息提交给表单验证
r1=obj.is_valid() #让他去验证,并返回值,有没有验证成功。成功返回True,不成功返回False
print(obj.cleaned_data)#验证成功的信息obj.cleaned_data里面
print(obj.errors)#验证错误的信息obj.errors里面(列表ul)
print(obj.errors.as_json()) 返回是字典

  2) form使用简单示例

#创建
from django import forms
class FM(forms.Form) from django import forms
class FM(forms.Form):
user=forms.CharField()
pwd=forms.CharField()
email=forms.EmailField()
#假如用户提交了很多数据过来,我怎么知道是那一个是我们需要验证的。
这里的user和form表单里的name值是一致的。即定义的字段和form表单里的name属性的值必须要一致 <form action="/fm/" method="post">
{% csrf_token %}
<input type="text" name="user">
<input type="password" name="pwd">
<input type="text" name="email">
<input type="submit" value="提交">
</form> #表单使用 obj=FM(request.POST) #把POST信息提交给表单验证
r1=obj.is_valid() #让他去验证,并返回值,有没有验证成功。成功返回True,不成功返回False
print(obj.cleaned_data)#验证成功的信息obj.cleaned_data里面
print(obj.errors)#验证错误的信息obj.errors里面(列表ul)
print(obj.errors.as_json()) 返回是字典
示例: def fm(request):
if request.method=="GET":
return render(request,'fm.html')
if request.method=="POST":
#获取用户所有数据
#每条数据请求的验证
#成功:获取所有正确的信息
#失败:显示错误信息
obj=FM(request.POST) #把POST信息提交给表单验证
r1=obj.is_valid() #让他去验证,并返回值,有没有验证成功。成功返回True,不成功返回False
print(r1)
if r1:
print(obj.cleaned_data)#验证成功的信息obj.cleaned_data里面
else:
print(obj.errors)#验证错误的信息obj.errors里面
return redirect("/index/") 结果:
False
<ul class="errorlist"><li>user<ul class="errorlist"><li>This field is required.</li></ul></li><li>pwd<ul class="errorlist"><li>This field is required.</li></ul></li><li>email<ul class="errorlist"><li>This field is required.</li></ul></li></ul> True
{'user': 'root', 'pwd': '`12', 'email': '123@126.com'} {"user": [{"message": "This field is required.", "code": "required"}], "pwd": [{"message": "This field is required.", "code": "required"}], "email": [{"message": "This field is required.", "code": "required"}]}

  3)上面错误都是英文,能不能定制。  

    #2)上面错误都是英文,能不能定制。
from django import forms
class FM(forms.Form):
#我只关心我关心的
user=forms.CharField(error_messages={'required':'用户名不能为空'})
pwd=forms.CharField(max_length=12,
min_length=6,
error_messages={'min_length':'密码长度不能小于6','max_length':'密码长度不能大于12','required':'密码不能为空'})
email=forms.EmailField(error_messages={'required':'邮箱不能为空','invalid':'邮箱格式错误'})
#假如用户提交了很多数据过来,我怎么知道是那一个是我们需要验证的。这里的user和form表单里的name值是一致的。

  4)错误信息传递给模板

    def fm(request):
if request.method=="GET":
return render(request,'fm.html')
if request.method=="POST":
#获取用户所有数据
#每条数据请求的验证
#成功:获取所有正确的信息
#失败:显示错误信息
obj=FM(request.POST) #把POST信息提交给表单验证
r1=obj.is_valid() #让他去验证,并返回值,有没有验证成功。成功返回True,不成功返回False
print(r1)
if r1:
print(obj.cleaned_data)#验证成功的信息obj.cleaned_data里面
else:
#obj.errors 继承了ErrirDict,是个字典obj.errors.user 会出错。正确写法:obj.errors["user"]
print(obj.errors)#验证错误的信息obj.errors里面
# print(obj.errors["user"][0])#拿到第一个错误信息
#把错误信息传递到模板
return render(request,'fm.html',{"obj":obj}) return render(request,'fm.html') fm.html <form action="/fm/" method="post">
{% csrf_token %}
<p><input type="text" name="user">
{{ obj.errors.user.0 }}
</p>
<p>
<input type="password" name="pwd">
{{ obj.errors.pwd.0 }}
</p>
<p><input type="text" name="email">
{{ obj.errors.email.0 }}</p>
<input type="submit" value="提交">
</form>

  5)上面错误信息显示了,但是原来输入的值没有了。上面不仅显示错误信息,还可以输出标签 

    <form action="/fm/" method="post">
{% csrf_token %}
<p>{{ obj.user }}
{{ obj.errors.user.0 }}
</p>
<p>
{{ obj.pwd }}
{{ obj.errors.pwd.0 }}
</p>
<p>{{ obj.email }}
{{ obj.errors.email.0 }}</p>
<input type="submit" value="提交">
</form>
但是上面没有显示输入框,因为第一次请求是GET,没有返回对象
所以GET模式要创建对象,不需要传递参数,但是变量名和POST一样。 def fm(request):
if request.method=="GET":
obj=FM()
return render(request,'fm.html',{"obj":obj})
if request.method=="POST":
#获取用户所有数据
#每条数据请求的验证
#成功:获取所有正确的信息
#失败:显示错误信息
obj=FM(request.POST) #把POST信息提交给表单验证
r1=obj.is_valid() #让他去验证,并返回值,有没有验证成功。成功返回True,不成功返回False
print(r1)
if r1:
print(obj.cleaned_data)#验证成功的信息obj.cleaned_data里面
else:
#obj.errors 继承了ErrirDict,是个字典obj.errors.user 会出错。正确写法:obj.errors["user"]
print(obj.errors)#验证错误的信息obj.errors里面
# print(obj.errors["user"][0])#拿到第一个错误信息
#把错误信息传递到模板
return render(request,'fm.html',{"obj":obj}) return render(request,'fm.html') #注意浏览器可能会自己加些东西显示。

  6)上面如果值如果正确。那就可以入库了

    #5)上面如果值如果正确。那就可以入库了
models.UserInfo.objects.create(**obj.cleaned_data) def fm(request):
if request.method=="GET":
obj=FM()
return render(request,'fm.html',{"obj":obj})
if request.method=="POST":
#获取用户所有数据
#每条数据请求的验证
#成功:获取所有正确的信息
#失败:显示错误信息
obj=FM(request.POST) #把POST信息提交给表单验证
r1=obj.is_valid() #让他去验证,并返回值,有没有验证成功。成功返回True,不成功返回False
print(r1)
if r1:
print(obj.cleaned_data)#验证成功的信息obj.cleaned_data里面
models.UserInfo.objects.create(**obj.cleaned_data)
return redirect("/index")
else:
#obj.errors 继承了ErrirDict,是个字典obj.errors.user 会出错。正确写法:obj.errors["user"]
print(obj.errors)#验证错误的信息obj.errors里面
# print(obj.errors["user"][0])#拿到第一个错误信息
#把错误信息传递到模板
return render(request,'fm.html',{"obj":obj})

  7)快速生成ul,p,table的form 页面

    1)验证用户请求
2)生成HTML(保留上一次输入的数据)
上面还支持另外种方式,但是还是建议使用上面,定制方便。 <body>
<form action="/fm/" method="post">
{% csrf_token %}
{{ obj.as_p }} #p标签方式显示
<input type="submit" value="提交">
</form> <form action="/fm/" method="post">
{% csrf_token %}
{{ obj.as_ul }} #显示列表
<input type="submit" value="提交">
</form> <form action="/fm/" method="post">
{% csrf_token %}
{{ obj.as_table }} #显示表格
<input type="submit" value="提交">
</form>
</body>

  8)怎么设置样式

#form字段
XXXField()字段本身只做验证
设置样式是inputext用插件widgets
user=forms.CharField(error_messages={'required':'用户名不能为空'},widget=widgets.Textarea(attrs={"class":"c1"})) from django import forms
from django.forms import widgets,fields
class FM(forms.Form):
#我只关心我关心的
user=fields.CharField(error_messages={'required':'用户名不能为空'},widget=widgets.Textarea(attrs={"class":"c1"}))
pwd=fields.CharField(max_length=12,
min_length=6,
error_messages={'min_length':'密码长度不能小于6','max_length':'密码长度不能大于12','required':'密码不能为空'})
email=forms.EmailField(error_messages={'required':'邮箱不能为空','invalid':'邮箱格式错误'})
#假如用户提交了很多数据过来,我怎么知道是那一个是我们需要验证的。这里的user和form表单里的name值是一致的。 fields包括了所有的XXField,推荐使用这种写法。
widgets包括了所有的插件

25)django-form使用的更多相关文章

  1. Django(5) session登录注销、csrf及中间件自定义、django Form表单验证(非常好用)

    一.Django中默认支持Session,其内部提供了5种类型的Session供开发者使用: 数据库(默认) 缓存 文件 缓存+数据库 加密cookie 1.数据库Session 1 2 3 4 5 ...

  2. django: form fileupload - 1

    本节介绍 Form 中一些字段类型的使用,以文件上传字段 FileField 为例:(注,其它字段和相关用法见官方文档中的 Forms -> Built-in Fields) 一,配置 urls ...

  3. django form表单验证

    一. django form表单验证引入 有时时候我们需要使用get,post,put等方式在前台HTML页面提交一些数据到后台处理例 ; <!DOCTYPE html> <html ...

  4. Django form模块使用心得

    最近用Django 写了一个网站,现在来分享一下对Django form 的一些心得. 一,创建一个表单 创建一个Form表单有两种方式: 第一种方式是继承于forms.Form,的一个子类,通过在f ...

  5. Python Web框架篇:Django Form组件

    Form简介 在HTTP中,表单(form标签),是用来提交数据的,其action属性说明了其传输数据的方法:如何传.如何接收. 访问网站时,表单可以实现客户端与服务器之间的通信.例如查询,就用到了表 ...

  6. 25.django Model

    django ORM基本配置 django中遵循 Code Frist 的原则,即:根据代码中定义的类来自动生成数据库表 1.修改project数据库配置 (1)settigs.py里面 默认 DAT ...

  7. Django form表单

    Form介绍 之前在HTML页面中利用form表单向后端提交数据时,都会写一些获取用户输入的标签并且用form标签把它们包起来.与此同时我们在好多场景下都需要对用户的输入做校验,比如校验用户是否输入, ...

  8. django Form组件

    django Form组件 Django的Form主要具有一下几大功能: 生成HTML标签 验证用户数据(显示错误信息) HTML Form提交保留上次提交数据 初始化页面显示内容 小试牛刀 1.创建 ...

  9. Django Form和ModelForm组件

    Form介绍 我们之前在HTML页面中利用form表单向后端提交数据时,都会写一些获取用户输入的标签并且用form标签把它们包起来. 与此同时我们在好多场景下都需要对用户的输入做校验,比如校验用户是否 ...

  10. 9.24 Django Form组件

    2018-9-23 20:10:04 这两天优化了自己图书管理系统 github 连接:https://github.com/TrueNewBee/pythonDemo 顺便整理了博客,写了好多总结, ...

随机推荐

  1. Winform数据库连接app.config文件配置

    1.添加配置文件 新建一个winform应用程序,类似webfrom下有个web.config,winform下也有个App.config;不过 App.config不是自动生成的需要手动添加,鼠标右 ...

  2. HBase操作命令总结

    1,如何运行HBase 1,如何查找hbase的安装目录 whereis用来查找程序的安装目录.帮助文档等等,如下: whereis hbase 结果如下,目录下一级包含bin的就是hbase的安装目 ...

  3. 想要开发自己的PHP框架需要那些知识储备?

    作者:安正超链接:https://www.zhihu.com/question/26635323/answer/33812516来源:知乎著作权归作者所有.商业转载请联系作者获得授权,非商业转载请注明 ...

  4. Django标签和过滤器

    过滤器格式{{   }} 标签格式{%  %} 模板中过滤器filter只能使用一个参数,自定义标签中则可以使用多个参数!!! 过滤器能够采用链式的方式使用,例如:{{ text | escape | ...

  5. redis优化

    一.配置文件优化 bind 127.0.0.1 //允许连接的ip,如果就本机连接最后127.0.0.1 protected-mode yes //是否开启保护模式.默认开启,如果没有设置bind项的 ...

  6. IE 11 flex布局兼容性问题 ---- 不支持min-height 和flex:1

    由于最近项目要嵌入其它平台,所以要做IE11 的兼容,那就用IE11打开网页看一看,一看吓一跳,页脚直接到了页眉的下面,并把主要内容覆盖了,也就是stick footer 布局失效了,我写了一个简易的 ...

  7. [模板] 二分图博弈 && BZOJ2463:[中山市选2009]谁能赢呢?

    二分图博弈 from BZOJ 1443 游戏(二分图博弈) - free-loop - 博客园 定义 1.博弈者人数为两人,双方轮流进行决策. 2.博弈状态(对应点)可分为两类(状态空间可分为两个集 ...

  8. koa-router 后台路由管理框架

    koa-router是koa框架配套的路由管理模块,对后台的接口分离出来. 首先引入koa和koa-router, 然后分批设置路由: 代码中的institution.modifyInsStatus是 ...

  9. pycharm设置主题

    步骤很简单: 1.下载皮肤主题(jar) 去 http://www.themesmap.com/ 选择自己喜欢的主题下载 2.导入皮肤主题 导入方法:file–>Import Setting–& ...

  10. Java执行jar总结

    1.命令集 1)nohup 用途:不挂断地运行命令. 语法:nohup Command [ Arg … ] [ & ] 无论是否将 nohup 命令的输出重定向到终端,输出都将附加到当前目录的 ...