form+ajax实现验证

#obj.errors返回的是ErrorDict,不是字典(虽然继承字典)
#obj.errors.as_json() 返回的字符串(前端要连续反解两次)
#obj.errors.as_data() 返回原生的字典 但是返回value 是ValidationError,不能直接序列化 1)通过errors.as_data()实现数据绑定和返回,errors.as_data() 返回原生的字典 但是返回value 是ValidationError,不能直接序列化,  通过json属性cls转换是ValidationError为字典返回。优点:前端jquery不需要JSON.parse转换两次。 2)通过errors.as_json()实现数据绑定和返回。as_json返回的是字符串。
前端返回:需要两次JSON.parse转换(第一次:HttpResponse返回的是字符串;第二次:
  返回的error字典中的value是字符串,需要在转成字典,才可以访问) 示例1:注册信息
#两种方式1:as_data(注意view中绑定方式和模板中jqeury调用方式)
froms.py
class RegisterForm(forms.Form):
username = fields.CharField(
error_messages={"required": "用户名不能为空"},
widget=widgets.Input(attrs={"class": "form-control"})
)
email = fields.EmailField(
error_messages={'required':'邮箱不能为空','invalid':'邮箱格式错误'},
widget=widgets.Input(attrs={"class": "form-control"})
)
password = fields.CharField(
error_messages={"required": "密码不能为空"},
widget=widgets.Input(attrs={"class": "form-control"})
)
password2 = fields.CharField(error_messages={"required": "密码不能为空"},
widget=widgets.Input(attrs={"class": "form-control"}))
check_code = fields.CharField(error_messages={"required": "验证码不能为空"},
widget=widgets.Input(attrs={"class": "form-control"})) def clean_username(self):
"""
验证用户存不存在
:return:
"""
obj = models.UserInfo.objects.filter(username=self.cleaned_data['username'])
# 用户存在返回原来的值
if not obj:
return self.cleaned_data['username']
else:
raise ValidationError(message="用户已存在,请更换其他用户名", code="xxxx") #views.py
from django.core.exceptions import ValidationError
class JsonCunstomEncode(json.JSONEncoder):
def default(self, field):
if isinstance(field,ValidationError):
return {"code":field.code,"message":field.message}
else:
return json.JSONEncoder.default(self,field) def register(request):
"""
注册
:param request:
:return:
"""
ret={"status":False,"error":None,"data":None}
if request.method=="GET":
register_obj=forms.RegisterForm()
return render(request, 'register.html',{"register_obj":register_obj})
elif request.method=="POST":
register_obj=forms.RegisterForm(request.POST)
if register_obj.is_valid():
ret["status"]=True
ret["data"]=register_obj.cleaned_data
else:
ret["error"]=register_obj.errors.as_data()
result=json.dumps(ret,cls=JsonCunstomEncode)
#不能使用render,使用render返回数据,前端var data1=JSON.parse(arg)转换报错。可以使用HttpResponse直接返回数据
#return render(request, 'register.html',{"result":result})
return HttpResponse(result)
模块实现:
<div class="register">
<div style="font-size: 25px; font-weight: bold;text-align: center;">
用户注册
</div>
<form role="form" id="register_form">
{% csrf_token %}
<div class="form-group">
<label for="username">用户名</label>
<input type="text" class="form-control" id="username" placeholder="请输入用户名" name="username">
<p id="error_username"></p>
</div>
<div class="form-group">
<label for="email">邮箱</label>
<input type="email" class="form-control" id="email" placeholder="请输入邮箱" name="email">
<p id="error_email"></p>
</div>
<div class="form-group">
<label for="password">密码</label>
<input type="password" class="form-control" id="password" placeholder="请输入密码" name="password">
<p id="error_password"></p>
</div>
<div class="form-group">
<label for="confirm_password">确认密码</label>
<input type="password" class="form-control" id="password" placeholder="请输入密码" name="password2">
<p id="error_password2"></p>
</div> <div class="form-group">
<label for="password">验证码</label> <div class="row">
<div class="col-xs-7">
<input type="password" class="form-control" id="password" placeholder="请输入验证码" name="check_code">
<p id="error_check_code"></p>
</div>
<div class="col-xs-5">
<img src="/check_code.html">
</div>
</div>
<p id="show_error"></p>
</div>
<a id="register_a" type="submit" class="btn btn-default" >下一步</a>
</form>
<script src="/static/js/jquery-1.12.4.js"></script>
<script src="/static/js/jquery.cookie.js"></script>
<script>
$("#register_a").click(
function(){
$.ajax({
url:'{% url "register" %}',
type:"POST",
//headers: {"X-CSRFtoken":$.cookie("csrftoken")},如果是用serialize,他就csrftoken一起发送过去,所以不需要加headers
data:$("#register_form").serialize(),
success:function(arg){
var data1=JSON.parse(arg);
console.log(data1);
//#如果返回的状态为false,输出出错的内容
if (!data1.status){
//清空所有error p标签的内容
$("#register_form").find('p[id*=error_]').each(
function(){
$(this).text("")
}
)
//根据错误信息动态绑定到p标签
for (var item in data1.error){
var tmp='#error_'+item+''
$(tmp).text(data1.error[item][0].message);
}
/*
手动绑定标签,但是会存在error中没有的信息报错
$("#error_username").text(data1.error["username"][0].message);
$("#error_email").text(data1.error.email[0].message);
$("#error_password").text(data1.error.password[0].message);
$("#error_password2").text(data1.error.password2[0].message);
$("#error_check_code").text(data1.error.check_code[0].message);
*/
}
else{
//跳转到后台
location.href='{% url "base_info" %}'
}
} })
}
)
</script> 方式2:as_json views.py
def register(request):
"""
注册
:param request:
:return:
"""
ret={"status":False,"error":None,"data":None}
if request.method=="GET":
register_obj=forms.RegisterForm()
return render(request, 'register.html',{"register_obj":register_obj})
elif request.method=="POST":
register_obj=forms.RegisterForm(request.POST)
if register_obj.is_valid():
ret["status"]=True
ret["data"]=register_obj.cleaned_data
else:
ret["error"]=register_obj.errors.as_json()
result=json.dumps(ret)
#不能使用render,使用render返回数据,前端var data1=JSON.parse(arg)转换报错。可以使用HttpResponse直接返回数据
#return render(request, 'register.html',{"result":result})
return HttpResponse(result)
模板: <div class="register">
<div style="font-size: 25px; font-weight: bold;text-align: center;">
用户注册
</div>
<form role="form" id="register_form">
{% csrf_token %}
<div class="form-group">
<label for="username">用户名</label>
<input type="text" class="form-control" id="username" placeholder="请输入用户名" name="username">
<p id="error_username"></p>
</div>
<div class="form-group">
<label for="email">邮箱</label>
<input type="email" class="form-control" id="email" placeholder="请输入邮箱" name="email">
<p id="error_email"></p>
</div>
<div class="form-group">
<label for="password">密码</label>
<input type="password" class="form-control" id="password" placeholder="请输入密码" name="password">
<p id="error_password"></p>
</div>
<div class="form-group">
<label for="confirm_password">确认密码</label>
<input type="password" class="form-control" id="password" placeholder="请输入密码" name="password2">
<p id="error_password2"></p>
</div> <div class="form-group">
<label for="password">验证码</label> <div class="row">
<div class="col-xs-7">
<input type="password" class="form-control" id="password" placeholder="请输入验证码" name="check_code">
<p id="error_check_code"></p>
</div>
<div class="col-xs-5">
<img src="/check_code.html">
</div>
</div>
<p id="show_error"></p>
</div>
<a id="register_a" type="submit" class="btn btn-default" >下一步</a>
</form>
<script src="/static/js/jquery-1.12.4.js"></script>
<script src="/static/js/jquery.cookie.js"></script>
<script>
$("#register_a").click(
function(){
$.ajax({
url:'{% url "register" %}',
type:"POST",
//headers: {"X-CSRFtoken":$.cookie("csrftoken")},如果是用serialize,他就csrftoken一起发送过去,所以不需要加headers
data:$("#register_form").serialize(),
success:function(arg){
//第一次转换
var data1=JSON.parse(arg);
console.log(data1);
//#如果返回的状态为false,输出出错的内容
if (!data1.status){
//清空所有error p标签的内容
$("#register_form").find('p[id*=error_]').each(
function(){
$(this).text("")
}
)
//第二次转换
var error_list=JSON.parse(data1.error)
//根据错误信息动态绑定到p标签
for (var item in error_list){
var tmp='#error_'+item+''
$(tmp).text(error_list[item][0].message);
}
/*
手动绑定标签,但是会存在error中没有的信息报错
$("#error_username").text(data1.error["username"][0].message);
$("#error_email").text(data1.error.email[0].message);
$("#error_password").text(data1.error.password[0].message);
$("#error_password2").text(data1.error.password2[0].message);
$("#error_check_code").text(data1.error.check_code[0].message);
*/
}
else{
//跳转到后台
location.href='{% url "base_info" %}'
}
} })
}
)
</script>

28)django-form+ajax实现验证的更多相关文章

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

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

  2. django form表单验证

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

  3. django form 表单验证

  4. [oldboy-django][2深入django]Form总结

    1 form总结 # Form数据格式验证 - 原理: - 流程 a.写类LoginForm(Form): 字段名 = fields.xxFields() # 验证规则,本质是正则表达式(fields ...

  5. Django基础——Form&Ajax篇

    一 Form 在实际的生产环境中,登录和注册时用户提交的数据浏览器端都会使用JavaScript来进行验证(比如验证输入是否为空以及输入是否合法),但是浏览器可能会禁用JavaScirpt,同时也有人 ...

  6. Day19 Django之Form表单验证、CSRF、Cookie、Session和Model操作

    一.Form表单验证 用于做用户提交数据的验证1.自定义规则 a.自定义规则(类,字段名==html中的name值)b.数据提交-规则进行匹配代码如下: """day19 ...

  7. the django travel three[form表单验证]

    一:表单验证: 场景:因为浏览器的js可以被禁用,所以需要做后台的输入合法的验证. A:ajax发请求.需要注意的是ajax POST的数据的key值和form表单的里的字段名字一致,否则得不到验证! ...

  8. 第三百一十一节,Django框架,Form表单验证

    第三百一十一节,Django框架,Form表单验证 表单提交 html <!DOCTYPE html> <html lang="en"> <head& ...

  9. 九 Django框架,Form表单验证

    表单提交 html <!DOCTYPE html> <html lang="en"> <head> <meta charset=" ...

随机推荐

  1. iOS拍照图片旋转的问题

    很久之前,遇到了这种情况,iOS某端拍照上传到服务器,其他iOS端从服务器下载该照片展示,发现图片逆时针旋转了90度.当时百度了一下,找到一段代码修正image方向,问题解决了,但没有深入理解底层原理 ...

  2. cocos2dx 3.3 笔记

    ccs3 加入了 rapidjson ->一个JSON解析库https://github.com/miloyip/rapidjson

  3. luogu P3172 [CQOI2015]选数

    传送门 颓了一小时柿子orz 首先题目要求的是\[\sum_{x_1=l}^{r}\sum_{x_2=l}^{r}...\sum_{x_n=l}^{r}[gcd(x_1,x_2...x_n)=k]\] ...

  4. npm 切换源 nrm

    版权声明:欢迎转载,请附加转载来源:一路博客(http://www.16boke.com) 转载 http://blog.csdn.net/wyc_cs/article/details/5155925 ...

  5. 第25月25日 urlsession

    1. private lazy var session: URLSession = { let configuration = URLSessionConfiguration.default conf ...

  6. 修复服务器上出现ImportError: cannot import name main的问题

    在服务器上成功升级pip2之后再运行pip2命令出现如下报错信息 Traceback (most recent call last): File "/usr/bin/pip2.7" ...

  7. oracle 清理跟踪文件trc,trm

    oracle的日志文件有以下几种: 警告日志,trace日志,audit日志,redo日志,归档日志 a.警告日志:也就是alert log,使用初始化参数 show parameter backgr ...

  8. OVS-----CentOS7上搭建基于Open vSwitch的VxLAN隧道实验

    一.关于VXLAN VXLAN 是 Virtual eXtensible LANs 的缩写,它是对 VLAN 的一个扩展,是非常新的一个 tunnel 技术,在Open vSwitch中应用也非常多. ...

  9. [转] 浅谈Trie树(字典树)

    原文地址:https://www.cnblogs.com/TheRoadToTheGold/p/6290732.html Trie树(字典树) 一.引入 字典是干啥的?查找字的. 字典树自然也是起查找 ...

  10. Elasticsearch 5.4.3实战--环境搭建

    1. 选择搭建的服务器信息 $ uname -a Linux SA0124 2.6.32-642.11.1.el6.x86_64 #1 SMP Fri Nov 18 19:25:05 UTC 2016 ...