Django中Form的基本使用
from django import forms
from django.forms import fields
class UserInfo(forms.Form):
username = fields.CharField(required=True,error_messages={
'required':'username不能为空'
}) # 正则表达式
password = fields.CharField(required=True,error_messages={
'required':'password不能为空'
})
email = fields.EmailField(required=True,error_messages={
'required':'email不能为空',
'invalid':'email格式错误'
}) #不能为空
# 获取用户提交的数据 request.POST
# 数据和正则表达式进行验证
# 1.是否验证成功
# 2.成功:获取数据
# 3.失败:显示错误信息
def add_user(request):
if request.method == 'GET':
return render(request,'add_user.html')
else:
obj = UserInfo(request.POST) # 定义一个form实例
# 获取是否验证成功 使用is_valid方法
if obj.is_valid():
print('验证通过',obj.cleaned_data)
models.UserInfo.objects.create(**obj.cleaned_data)
else:
print('错误信息',obj.errors)
总结:
Form验证:
a.Form类
b. obj = Form()
obj.username <input .../>
c. obj = Form(request.POST)
obj.username <input value=..../>
d. 验证
if obj.is_valid()
print('数据信息',obj.cleaned_data)
models.UserInfo.objects.create(**obj.cleaned_data)
else:
print('错误信息',obj.errors)
print('错误信息',obj.errors.usernaem[0])
return render(request,'add_user/',{'obj':obj})
===============>
Form 生成HTML标签
在index中添加 {{ obj.usernaem }} 自动生成html标签
from django.forms import widgets
widget=widgets.TextInput(attr={'class':'xxxx'}) #设置标签类型
Form 编辑
#============urls.py================
from app01 import views
urlpatterns = [
url(r'edit_user/(?P<uid>\d+)',views.edit_user),
]
#============views.py================
from django import forms
from django.forms import fields
from django.forms import widgets
class UserForm(forms.Form):
username = fields.CharField(
required=True,
error_messages = {'required':'username不能为空'},
widget = widgets.TextInput(attrs={'class':'form-control','placeholder':'用户名'}),
)
password = fields.CharField(
required = True,
error_messages = {'required':'password不能为空'},
widget = widgets.TextInput(attrs={'class':'form-control','placeholder':'密码'}),
)
email = fields.CharField(
required = True,
error_messages = {'required':'email不能为空'},
widget = widgets.TextInput(attrs={'class':'form-control','placeholder':'邮件'}),
)
from app01 import models
def edit_user(request,uid):
if request.method == 'GET':
user_obj = models.UserInfo.objects.filter(id=uid).first()
obj = UserForm(initial={'username':user_obj.username,'password':user_obj.password,'email':user_obj.email})
#或者
# user = models.UserInfo.objects.values('username','password','email').filter(id=uid).first()
# obj = UserForm(initial=user)
return render(request,'edit_user.html',{'obj':obj,'uid':uid})
elif request.method == 'POST':
obj = UserForm(request.POST)
if obj.is_valid():
models.UserInfo.objects.filter(id=uid).update(**obj.cleaned_data)
return redirect('/index1/')
else:
return render(request,'edit_user.html',{'obj':obj,'uid':uid})
Form中的select下拉框:
ut_id = fields.IntegerField(
required=True,
widget = widgets.Select(
attrs = {'class':'form-control'},
choices = [],
)
)
def __init__(self,*args,**kwargs)
super(UserForm,self).__init__(*args,**kwargs)
self.fields['ut_id'].widget.choices = models.UserType.values_list('id','usertype')
Form 小结:
1. 做提交数据的验证
2. 生成对应的HTML
3.
跨表操作时的数据库性能
select_related('Forkey')
Django中Form的基本使用的更多相关文章
- Django中Form验证
Django的Form主要具有一下几大功能: 生成HTML标签 验证用户数据(显示错误信息) HTML Form提交保留上次提交数据 初始化页面显示内容 一,Form验证 第一种操作:主要是这三个函数 ...
- django中form表单的提交:
一,关于表单: 表单在百度百科的解释: 表单在网页中主要负责数据采集功能.一个表单有三个基本组成部分: 表单标签:这里面包含了处理表单数据所用CGI程序的URL以及数据提交到服务器的方法. 表单域 ...
- Django 中 form 介绍
目录 Form介绍 我们之前在HTML页面中利用form表单向后端提交数据时,都会写一些获取用户输入的标签并且用form标签把它们包起来. 与此同时我们在好多场景下都需要对用户的输入做校验,比如校验用 ...
- Django中Form组件的使用
Form介绍 HTML页面中利用form表单向后端提交数据时,都会写一些获取用户输入的标签并且用form标签把它们包起来. 与此同时我们在好多场景下都需要对用户的输入做校验,比如校验用户是否输入,输入 ...
- django中form组件
Form介绍 我们之前在HTML页面中利用form表单向后端提交数据时,都会写一些获取用户输入的标签并且用form标签把它们包起来. 与此同时我们在好多场景下都需要对用户的输入做校验,比如校验用户是否 ...
- 如何写django中form的测试用例
可简可繁, 可插库,可字符, 要测试valid,也要测试invalid, 可用csrf,也可用context. 放一个全面的, 实践中,找一个最优的组合就好. class NewTopicTests( ...
- Django 中form的用法
form的主要作用:1.在html中生成表单框架,2.验证数据(实话实说,很简洁,但不实用,灵活性差) from django.db import models # Create your model ...
- Django中Form的Textarea字段
开始以为是这个样子: class BlogForm(forms.Form): title = forms.CharField(required = True) content = forms. ...
- django中form页面刷新后自动提交的解决方案
如果一个页面包含了form,同时这个form中的提交按钮是type=submit的input的时候,你刷新该页面,就会有弹窗提示是否重新提交表单,这个特性不胜其烦,常见解决方法有两个: 第一种是前端的 ...
随机推荐
- Angular.js 1++快速上手
AngularJS诞生于2009年,由Misko Hevery 等人创建,后为Goole所收购.是一款优秀的前端JS框架.AngularJS有着诸多特性,最为核心的是:MVC,撗块化,自动化双向数据绑 ...
- day-6 机器学习概念及应用
学习玩Python基础语法,今天开始进行机器学习,首先了解下机器学习和深度学习的一些基本概念和术语: 1. 机器学习概念及应用 2. 深度学习概念及应用 3. 机器学习基本术语及举例 4. 机 ...
- typescript简介
微软作为编译器狂魔一直有一个心病,就是改良JavaScript这种语法超级烂又很多人用的编程语言,于是TypeScript诞生了 先做个对比吧: TS JS 语法严谨性 严谨 宽松 静态性 静态 ...
- 09_Python定义方法_Python编程之路
有关Python判断与循环的内容我们上几节已经跟大家一起学习了,这一节我们主要针对def 做一个讲解 def 定义一个方法 在项目编程中,我们往往要做很多重复的事,比如一个排序的功能(当然Python ...
- vuex commit保存数据技巧
vuex 单向数据流,推荐的commit 改变state数据,写起来非常繁琐,因为改数据可能要写很多commit函数. 依据我的理解,单向数据流主要是为了避免数据混乱,便于调试. 说白了,就是一个数据 ...
- evel()与JSON.parset()的区别
var x=alert("hello")evel("x");eval() 函数可计算某个字符串,并执行其中的的 JavaScript 代码:消耗大量内存,尤其是 ...
- 将一个javaWeb应用跑在Docker里
安装docker,本实例使用的是CentOS 7,其他系统的安装请自行百度. 安装:yum -y install docker 启动:service docker start docker的一些基本命 ...
- 使用hue查看hdfs系统报无法访问:/user/hadoop。 Note: you are a Hue admin but not a HDFS superuser, "hdfs" or part of HDFS supergroup, "supergroup".
出现这个问题,是因为默认的超级用户是hdfs ,我的是hadoop用户登录的, 也就是说首次登录hadoop这个用户是我的超级用户 此时只需要将hue.ini配置改为 然后重启即可.
- Javascript中的url编码与解码(详解)
摘要 本文主要针对URI编解码的相关问题做了介绍,对url编码中哪些字符需要编码.为什么需要编码做了详细的说明,并对比分析了Javascript中和编解码相关的几对函数escape / unescap ...
- oracle11.2中分区功能测试之add&split partition对global&local index的影响
生产库中某些大表的分区异常,需要对现有表进行在线操作,以添加丢失分区,因为是生产库,还是谨慎点好,今天有空,针对add&split分区对global&local索引的影响进行了测试,测 ...