Django中的Form组件功能:

1.对用户请求的验证

2.生成html代码

Form使用:对用户请求进行验证

前端代码:

<form action="/f1.html" method="post" id="fm">
<p>
<input type="text" name="user">{{ obj.errors.user.0 }} #获取错误信息.0去掉换行
</p>
<p>
<input type="password" name="pwd">{{ obj.errors.pwd. }}
</p>
<p>
<input type="text" name="email">{{ obj.errors.email. }}
</p>
<p>
<input type="text" name="age">{{ obj.errors.age. }}
</p>
{% csrf_token %}
<input type="submit" value="提交">
</form>

服务端:

from django import forms
from django.forms import fields class F1Form(forms.Form):
#下面数据字段名,对于前端表单中name
user = fields.CharField(
max_length=,
min_length=,
required=True,
error_messages={
'required':"用户名不为空",
'min_length':"太短了",
'max_length':"太长了",
}
)
pwd = fields.CharField(required=True,min_length=)
age = fields.IntegerField(
required=True,
error_messages={
'invalid':"不对"
}
)
email = fields.EmailField(required=True,min_length=) def f1(req):
if req.method == "GET":
return render(req,"f1.html")
else:
#检测是否为空
#检测格式是否正确
obj = F1Form(req.POST)
if obj.is_valid():
#验证成功
return HttpResponse("ok")
else:return render(req,"f1.html",{"obj":obj})

2.生成html:指的是在客户端中和服务端表单中为了保证name和字段一致,将表单设置为字段(自动生成表单),就是生成html代码

服务端:

def f1(req):
if req.method == "GET":
obj = F1Form()
return render(req,"f1.html",{"obj":obj})

客户端:

<form action="/f1.html" method="post" id="fm">
<p>{{ obj.user }}{{ obj.errors.user. }} #因为get请求中没有在form组件中传入值,所以不会产生相关错误信息,为空,不显示
</p>
<p>
{{ obj.pwd }}{{ obj.errors.pwd. }}
</p>
<p>
{{ obj.email }}{{ obj.errors.email. }}
</p>
<p>
{{ obj.age }}{{ obj.errors.age. }}
</p>
{% csrf_token %}
<input type="submit" value="提交">
<input type="button" value="ajax提交" onclick="submitAjaxForm();">
</form>

补充:在添加数据库时,保持前端name,form验证字段,models字段名一致,会便于数据添加:

前端:

      <form action="/add_user.html" method="post">
<p>{{ obj.username }}{{ obj.errors.username }}</p>
<p>{{ obj.email }}{{ obj.errors.email }}</p>
{% csrf_token %}
<input type="submit" value="提交">
</form>

form组件:

class UserForm(Form):
username = fields.CharField(max_length=,required=True)
email = fields.EmailField(required=True,min_length=)

models添加数据:

    if req.method == "POST":
obj = UserForm(req.POST)  #前端name和form字段一致时,可以直接传递req.POST
if obj.is_valid():
User.objects.create(**obj.cleaned_data) #form字段和models字段一致时,可以直接将检验成功的数据传入
return redirect("add_user.html")

补充2:为form组件生成html代码是设置默认数据

def edit_user(req):
data = models.user.objects.filter(id=req.GET.get("nid")).first()
obj = UserForm({"username":data.username,"email":data.email}
return render("edit_user.html",{"obj":obj})  #会在obj中添加上默认数据

form组件字段介绍:

CharField字段介绍:

field_test = fields.CharField(
required=True,
max_length=,
min_length=,
error_messages={
'required':"必须填写"
},
#widget = widgets.Select(choices=[(1,'aa'),(2,'dd'),]),#定制html插件,就是将该字段设置为select表单格式
label="用户名",
# initial="ccc", #只能对text格式设置,对于select等有其他方法
help_text="fawf", #帮助文本
show_hidden_initial=True, #隐藏框
validators=[],#自定义验证规则
disabled=True, #设置不可编辑
     localize = True, #设置支持本地化
     label_suffix="fawf", #设置label后缀 )

前端使用:

<p>{{ obj.field_test.label }}{{ obj.field_test }}{{ obj.field_test.email }}</p>

注:可以使用obj.as_p,as_table,as_ul将表单一次输出(方便,但是灵活性小了,自定义样式不方便,不推荐)

{{ obj.as_p }}

补充:文件上传验证:

FileField

form组件:

file = fields.FileField(required=True)

前端:

注意上传文件需要enctype = "mulipart/form-data"
{{ obj.file }}

服务端:

obj = TestForm(req.POST,req.FILES) #含文件上传时需要将文件传入

ChoiceField:下拉框

city = fields.ChoiceField(
choices = [(,"aa"),(,"bb"),(3,"cc"),],
     initial = 2, #默认第二项
) 默认设置:
TestForm({"city":3}) #默认第三个选中

MultipleChoiceField()多选下拉框

initial=[,,]设置默认值多个

TypedChoiceField()继承于ChioceField()可以对接受的数据进行类型转换

coerce = lambda x: int(x)将字符串转整型

ComboField()组合验证规则进行验证

fields.COmboField(fields.CharField(max_length=),fields.EmailField(required=True),)

.......

python---django中form组件(1)简单使用和字段了解的更多相关文章

  1. django框架中form组件的简单使用示例:注册验证

    Django中form组件的三大特点: 1. 生成页面可使用的HTML标签 2. 对用户提交的数据进行初步校验    3. 保留上次输入内容 废话不多说,直接进入正题. 这是注册界面截图: 与上一篇a ...

  2. python Django之Form组件

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

  3. Django中Form组件的使用

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

  4. django中form组件

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

  5. Django中form组件的is_valid校验机制

    先来归纳一下整个流程(1)首先is_valid()起手,看seld.errors中是否值,只要有值就是flase(2)接着分析errors.里面判断_errors是都为空,如果为空返回self.ful ...

  6. Python之路【第二十一篇】:Django之Form组件

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

  7. python框架之Django(10)-Form组件

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

  8. 〖Python〗-- Django的Form组件

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

  9. RSA算法在Python Django中的简单应用

    说明 RSA算法是当今使用最广泛,安全度最高的加密算法. • RSA算法的安全性理论基础 [引]根据百科介绍,对极大整数做因数分解的难度决定了RSA算法的可靠性.换言之,对一极大整数做因数分解愈困难, ...

  10. Django 之 Form 组件

    常用功能 From 组件主要有以下几大功能: 生成 HTML 标签 验证用户数据(显示错误信息) HTML Form 提交保留上次提交数据 初始化页面显示内容 小试牛刀 下面我们通过 Form 组件来 ...

随机推荐

  1. DICOM 协议学习笔记之 How Does DICOM Work ?

    How Does DICOM Work ? DICOM有一套自己自己的模型体系,在进行具体介绍之前,首先讲解下DICOM模型: 在DICOM世界当中,所有的包括患者.检查.医学设备等都可以被视为具有不 ...

  2. Celery基本使用

    Celery 什么是Celery? Celery是一种简单/高效/灵活的即插即用的分布式任务队列. Celery应用场景? 需要异步处理的任务,发邮件/发短信/上传等耗时的操作.最终到达提升用户体验的 ...

  3. [2017BUAA软工助教]剩余个人作业与deadline

    软件工程剩余作业与deadline 标签(空格分隔): 软件工程 一.个人阅读作业+总结 对软件工程的学习做一个总结. 阅读下列关于软件开发本质和开发方法的博客/文章,结合自己在个人项目/结对编程/团 ...

  4. LeetCode 88. 合并两个有序数组

    题目: 给定两个有序整数数组 nums1 和 nums2,将 nums2 合并到 nums1 中,使得 num1 成为一个有序数组. 说明: 初始化 nums1 和 nums2 的元素数量分别为 m ...

  5. 英语学习APP

    第一部分 调研, 评测 下载并使用,描述最简单直观的个人第一次上手体验. 界面高大上,看起来很美观,是个不错的英语学习软件.我很喜欢. 2.按照<构建之法>13.1节描述的 bug 定义, ...

  6. PAT乙级(Basic Level)练习题-NowCoder数列总结

    题目描述 NowCoder最近在研究一个数列: F(0) = 7 F(1) = 11 F(n) = F(n-1) + F(n-2) (n≥2) 他称之为NowCoder数列.请你帮忙确认一下数列中第n ...

  7. [问题排查]记录一次两个dubbo提供者同时在线,代码不一致导致问题的排查记录

    1. 需求 有一个需求job定时5秒一次,job[消费者]调用dsc[提供者]提供的dubbo完成:先清空redis的某个key,然后再往redis中放入新的数据,这是一个定时任务,需要每隔5秒执行一 ...

  8. Linux kernel 发布 5.0-rc1 版本

    Linux kernel 要发布 5.0 了.. 跟原因是 linus 认为 4.21的小版本号太多了... 邮件内容如下: https://lore.kernel.org/lkml/20190107 ...

  9. Kivy 中文教程 实例入门 简易画板 (Simple Paint App):0. 项目简介 & 成果展示

    本教程咪博士将带领大家学习创建自己的窗口部件 (widget).最终,我们完成的作品是一个简易的画板程序. 当用 kivy 创建应用时,我们需要仔细思考以下 3 个问题: 我们创建的应用需要处理什么数 ...

  10. 【IneliJ 】使用IneliJ IDEA 2016将Java Web项目导出为War包

    本文记录使用IDEA导出war包的过程以及碰到问题的解决办法 虽说现在改用IDEA进行开发了,但还是用eclipse打war包 ….囧 这样下去不是办法... 于是今天就试着使用IDEA进行打包. 项 ...