django_forms组件用ajax发送数据验证注册
forms组件
-forms是什么?
就是一个类,可以校验字段(前台传过来的字段)
-怎么用:
-校验字段功能:
-先写一个类,继承Form
from django.shortcuts import render, HttpResponse
from django import forms
# 写一个类,要校验那些字段,就是类的属性
class MyForm(forms.Form):
# 定义一个属性,可以用来校验字符串类型
# 限制最大长度是8,最小长度是3
name=forms.CharField(max_length=,min_length=)
pwd=forms.CharField(max_length=,min_length=,required=True)
# 校验是否是邮箱格式
email=forms.EmailField()
-使用:
#实例化产生对象,传入要校验的数据(字典)
myform=MyForm(request.POST)
# is_valid如果是true表示校验成功,反之,校验失败
if myform.is_valid():
# 校验通过的数据
print(myform.cleaned_data)
return HttpResponse('校验成功')
else:
print(myform.cleaned_data)
#校验失败的信息
print(myform.errors)
-注意:校验的字段,可以多,但是不能少
-渲染模板
-第一中方式:(灵活性最高)
<form action="" method="post" >
<p>用户名: {{ myform.name }}</p>
<p>密码: {{ myform.pwd }}</p>
<p>邮箱: {{ myform.email }}</p>
<input type="submit" value="提交">
</form>
-第二种方式:for循环form对象(用的比较多):
<form action="" method="post" >
{% for foo in myform %}
<p>{{ foo.label }}:{{ foo }}</p>
{% endfor %}
<input type="submit" value="提交">
</form>
-第三种方式(不建议用):
<form action="" method="post" > {# {{ myform.as_p }}#}
{{ myform.as_ul }}
<input type="submit" value="提交">
</form> -渲染错误信息
- myforms有errors
-属性(name)也有errors
-错误信息,变成中文:
- error_messages={'max_length': '最长是8', 'min_length': '最短是3', 'required': '这个必须填','invalid': '不符合邮箱格式'}
-给input标签指定样式,指定格式:
-widget=widgets.TextInput(attrs={'class':'form-control'})
-模板,渲染错误信息:<span>{{ myform.name.errors. }}</span>
-局部钩子校验
-定义一个函数,名字叫:clean_字段名字,内部,取出该字段,进行校验,如果通过,将该字段返回,如果失败,抛异常(ValidationError)
- def clean_name(self):
# self:当前form对象
name = self.cleaned_data.get('name')
if name.startswith('sb'):
# 失败,抛异常
raise ValidationError('不能以傻逼开头')
# 正常,把name返回
return name
-全局钩子
#重写clean方法
def clean(self):
#程序能走到该函数,前面校验已经通过了,所以可以从cleaned_data中取出密码和确认密码
pwd=self.cleaned_data.get('pwd')
re_pwd=self.cleaned_data.get('re_pwd')
#进行自己的校验
if pwd==re_pwd:
#通过,直接返回cleaned_data
return self.cleaned_data
else:
#失败,抛异常(ValidationError)
raise ValidationError('两次密码不一致'
---------------------------------views代码--------------------------------------------------
from django.shortcuts import render, HttpResponse,redirect from django.http import HttpRequest, JsonResponse # Create your views here.
# ---------------------//-----------------------
from django import forms
from django.core.exceptions import ValidationError
from django.forms import widgets
from app01 import models class MyForm(forms.Form):
name = forms.CharField(max_length=, min_length=, label='用户名', error_messages={
'max_length': '最长是8个字符',
'min_length': '最短是3个字符',
'required': '这个必须填'
},widget=widgets.TextInput(attrs={'class': 'form-control'}))
pwd = forms.CharField( max_length=, min_length=, required=True, label='密码',
error_messages={
'max_length': '最长是8个字符',
'min_length': '最短是3个字符',
'required': '这个必须填'
},widget=widgets.PasswordInput(attrs={'class': 'form-control'}))
re_pwd = forms.CharField( max_length=, min_length=, required=True, label='请再次输入密码',
error_messages={
'max_length': '最长是8个字符',
'min_length': '最短是3个字符',
'required': '这个必须填'
},widget=widgets.PasswordInput(attrs={'class': 'form-control'}))
email = forms.EmailField(label='邮箱', error_messages={
'required': '这个必须填',
'invalid': '不符合邮箱格式'
},widget=widgets.TextInput(attrs={'class': 'form-control'})) def clean_name(self):
name = self.cleaned_data.get('name') name_list = models.Book.objects.all()
for user_name in name_list: if user_name.name == name:
raise ValidationError('用户已存在') return name
def clean(self):
pwd = self.cleaned_data.get('pwd')
re_pwd = self.cleaned_data.get('re_pwd')
if pwd == re_pwd:
return self.cleaned_data
else:
raise ValidationError('两次密码输入不一致') def form(request):
if request.method == 'GET':
myform = MyForm()
print(request.GET)
return render(request,'form1.html',locals())
elif request.method == 'POST':
# print(request.POST)
# print(request.body) print('在这---------------------------------------')
# print(request.body)
user_info = json.loads(request.body.decode('utf-8'))
print(user_info)
myform = MyForm(user_info)
# myform = MyForm(request.POST)
# print(myform) # return HttpResponse()
# print(myform)
if myform.is_valid():
print('')
data = myform.cleaned_data
print(data)
return JsonResponse(,safe=False)
# return HttpResponse(data)
else:
# all_error = myform.errors.get('__all__')
# print('pppppp')
# print(myform.errors)
# print(all_error)
# if all_error:
# all_error = all_error[]
return JsonResponse(myform.errors)
--------------------------------前端代码------------------------------------------------------
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<title>Title</title>
<script src="/static/jquery-3.3.1.min.js"></script>
<link rel="stylesheet" href="https://cdn.jsdelivr.net/npm/bootstrap@3.3.7/dist/css/bootstrap.min.css"
integrity="sha384-BVYiiSIFeK1dGmJRAkycuHAHRg32OmUcww7on3RYdg4Va+PmSTsz/K68vbdEjh4u" crossorigin="anonymous">
</head>
<body>
<div class="col-md-4 col-md-offset-4">
<form novalidate class="form-horizontal">
<div> {% for foo in myform %}
{# <p>{{ foo.label }} : {{ foo }} <span>{{ foo.errors.0 }}</span></p>#}
<p>{{ foo.label }} : {{ foo }} <span id="{{ foo.name }}_box" style="color: red"></span></p> {% endfor %}
{# <p>#}
{# <button id="btn" class="btn btn-primary">提交</button>#}
{# <span>{{ all_error }}</span>#}
{# </p>#}
</div>
</form>
<button id="btn" class="btn btn-primary">提交</button>
<span id="btn_box"></span>
</div>
</body>
<script>
$('#btn').click(function () { var user_info = {
'name': $('#id_name').val(),
'pwd': $('#id_pwd').val(),
're_pwd': $('#id_re_pwd').val(),
'email': $('#id_email').val()
};
var pos = JSON.stringify(user_info);
$.ajax({
url: '/form1/',
type: 'post',
contentType: 'application/json',
dataType: 'json',
data: pos,
success: function (data) {
console.log(data);
{#var span = '<span></span>';#}
if (data == 200) {
alert('注册成功')
} for (info in data) {
console.log('222');
if (info == 'name') {
$('#name_box').text(data[info]);
console.log('333') }
if (info == 'pwd') {
$('#pwd_box').text(data[info]);
console.log('333') }
if (info == 're_pwd') {
$('#re_pwd_box').text(data[info]);
console.log('333') }
if (info == 'email') {
$('#email_box').text(data[info]);
console.log('333') }
if (info == '__all__') {
$('#btn_box').text(data[info]);
console.log('333') } } } }) });
$('#id_name').blur(function () {
var user_name = {'name':$('#id_name').val()};
$.ajax({
url: '/form1/',
type: 'post',
contentType: 'application/json',
dataType: 'json',
data: JSON.stringify(user_name),
success: function (data) {
$('#name_box').text(data['name']); }
}) }) </script>
</html>
django_forms组件用ajax发送数据验证注册的更多相关文章
- Django进阶(路由系统、中间件、缓存、Cookie和Session、Ajax发送数据
路由系统 1.每个路由规则对应一个view中的函数 url(r'^index/(\d*)', views.index), url(r'^manage/(?P<name>\w*)/(?P&l ...
- Django——Ajax发送请求验证用户名是否被注册
场景: 用户注册的时候,输入用户名之后,Ajax发送请求到后端,后端验证该用户名是否已经被注册,然后返回到注册页面提示用户. 1.模型: from django.db import models cl ...
- jQuery——通过Ajax发送数据
Ajax(Asynchronous JavaScript and XML,异步JavaScript和XML),一个Ajax解决方案涉及如下技术: JavaScript:处理与用户及其他浏览器相关事件的 ...
- 2-功能1:基于用户认证组件和Ajax实现登录验证(图片验证码)
1.登录页面的设计 (1)label标签的id属性 label标签的id属性,点击label标记,相当于点击了input框 bootstarp样式 class="form-group&quo ...
- 前台Ajax发送数据给后台
前台发ajax请求给后台 前台代码 let data= [{receiveAdd:receiveAddVal, sendAdd:sendAddVal,distance:distance,goodsNa ...
- 测试ajax发送数据时在控制台看不到请求信息
都是因为我把alert(xmlhttp);alert(url);打印测试数据放到了xmlhttp.open("GET",url,true);之前,导致后面的发送请求不执行了!
- 在.net MVC项目中使用ajax进行数据验证
1.首先要在网页引入应该引入的js文件 在这里回顾一下在模板页里面挖坑的技术 2.在html中使用html辅助方法 3.验证模型 4验证方法
- Ajax发送数据
- Ajax发送POST请求对数据的封装
Ajax发送POST请求把数据到后端后,后端收到数据并解析出来 示列一: Ajax发送请求,这里主要是发送一个数组的数据类型到后端,如果没有先把数组进行格式化成字符串的话,后端就收了就是一个字符串类型 ...
随机推荐
- Scala具体解释---------控制结构和函数
条件表达式: Scala的if else语法结构和Java的一样.只是,Scala的if else表达式有值.这个值就是跟在if或者else后面的表达式的值. 比如: if(x>0) 0 els ...
- location alias与root
网站的根目录是:/alidata/www/webtest [root@M webtest]# tree /alidata/www/ /alidata/www/ ├── abc.html └── web ...
- JS高程3:DOM-DOM操作技术
动态脚本 加载外部脚本 方式一,直接写代码: var script = document.createElement("script"); script.type = " ...
- shell 实现mysql写入操作
mysql -uroot study -proot << EOF > insert into top_n_movie(movie,sumprice)values('hello kit ...
- matlab和C/C++混合编程--Mex (转载)
matlab和C/C++混合编程--Mex 最近的项目需要matlab和C的混合编程,经过一番努力终于完成了项目要解决的问题.现在就将Mex的一些经验总结一下,当然只是刚刚开始,以后随着学习的深入继续 ...
- NGUI本地化
之前在网上的NGUI本地化教程是基于老版本的了,现在用的3.7版本已经改了很多,以前的本地化教程有点不适用了. 1.资源: 本地化的txt文本起名叫做Chinese.txt,到resource目录下新 ...
- [工具04]java实现获取鼠标的坐标
本篇博客其实没什么难度可言,在这里分享给大家,是因为有时候我们需要这个工具,java作为跨平台语言的优势在这个软件就可以体现出来,不需修改就可以在windows.mac.linux上使用这个软件. 这 ...
- Buffer ByteBuffer 缓冲区
http://blog.sina.com.cn/s/blog_4150f50c0100gfa3.html
- 安装loadrunner时出现”命令行选项语法错误键入命令 \?获得帮助“的解决方法
安装LR11 时,安装Microsoft Visual c++2005 sp1运行时组件,就会提示命令行选项语法错误,键入“命令/?”可获取帮肋信息1.进入loadrunner-11\Addition ...
- Mathematica之基本操作
1.清楚所有变量 Clear["Global`*"];