需求

from表单验证和ajax验证时返回的错误信息处理

速查

1、form表单提交时错误信息显示

views

1
2
error = form表单实例化对象.errors
return render(request,'前端html',{'obj':form表单实例化对象,'error':error})    #传到前端用simple_tag解析

html

1
2
{% load xx %}    <!--导入自定义sample_tag语言文件-->
<span>{% error_msg error.username %}</span>    <!--error.username当做参数传给error_msg函数,并获取返回值-->

simple_tag

1
2
3
4
5
@register.simple_tag
def error_msg(error_list):
    if error_list:
        return error_list[0]
    return ''

2、ajax提交时错误信息返回

views

1
2
error = obj.errors.as_json()
return HttpResponse(error)

html

1
2
3
4
5
6
$.ajax({
            success: function(arg){                //arg是返回值,必须是字符串
                var callback_dict = $.parseJSON(arg);
                $('#uname_error').text(callback_dict.username[0].message);
            }
        })

知识点

obj=表单生成文件.表单创建的类(request.POST)

request.POST:所有提交信息

obj.is_valid():判断提交数据是否正确

obj.clean():获取提交的所有数据

obj.errors():获取提交的所有错误信息,有三种表示方式(as_ul、as_json、as_data):

  • form表单提交用默认的,type<class django.forms.utils.ErrorDict>

  • ajax返回信息用as_json(),type<'str'>

错误信息里包含的字段和form里的字段一样,错误是个列表,取值obj.errors['username'][0]

html中jinja2语法取字典是不能用errors['key']的方式,得用errors.key;如果获取obj.errors['username'][0],就得用sample_tag

详细

1、form表单提交时错误信息显示

app01/views/account.py
1
2
3
4
5
6
7
8
9
10
11
from app01.forms import account as AccountForm
 
def login(request):
    obj = AccountForm.LoginForm(request.POST)
    if request.method=='POST':
        if obj.is_valid():
            all_data = obj.clean()
        else:
            error = obj.errors
            return render(request,'account/login.html',{'obj':obj,'error':error})
    return render(request,'account/login.html',{'obj':obj})

为什么使用sample_tag去取值,而不取好了再传到html,因为如果字段很多的话,要分别定义每个的错误;
templates/login.html
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
{% load xx %}    <!--导入自定义sample_tag语言文件-->
<html lang="en">
<head></head>
<body>
    <form action="/login/" method="post">
        <p>
            {{ obj.username }}
            <span>{% error_msg error.username %}</span>    <!--error.username当做参数传给error_msg函数,并获取返回值-->
        </p>
        <p>
            {{ obj.password }}<span>{% error_msg error.password %}</span>
        </p>
        <input type="submit" value="submit" />
    </form>
</body>
</html>
app01/templatetags/xx.py
1
2
3
4
5
6
7
8
9
10
from django import template
from django.utils.safestring import mark_safe
from django.template.base import resolve_variable, Node, TemplateSyntaxError
 
register = template.Library()
 
@register.simple_tag
def error_msg(error_list):
    if error_list:
        return error_list[0]
browser

2、ajax提交时错误信息返回

ajax必须返回的是字符串,所以用as_json()格式。

先看as_json获取的信息格式

1
2
3
4
5
6
7
8
{
    "username": [
        {"message": "This field is required.", "code": "required"}
    ],
    "password": [
        {"message": "This field is required.", "code": "required"}
    ]
}

app01/views/account.py

1
2
3
4
5
6
7
8
9
10
11
from app01.forms import account as AccountForm
 
def login(request):
    obj = AccountForm.LoginForm(request.POST)
    if request.method=='POST':
        if obj.is_valid():
            all_data = obj.clean()
        else:
            error = obj.errors.as_json()
            return HttpResponse(error)
    return render(request,'account/login.html',{'obj':obj})

templates/login.html

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
<form action="/login/" method="post">
    <p>
        {{ obj.username }}
        <span id="uname_error"></span>
    </p>
    <p>
        {{ obj.password }}
        <span id="pwd_error"></span>
    </p>
{#        <input type="submit" value="submit" />#}
    <input type="button" value="AjaxSubmit" onclick="AjaxSubmit();"/>
</form>
 
<script src="{{ STATIC_URL }}js/jquery-2.1.4.min.js"></script>
<script type="text/javascript">
    function AjaxSubmit(){
        $.ajax({
            url: '/login/',
            type: 'POST',
            data: {'username':'','password':''},    //就当提交了一个空数据,制造错误
            success: function(arg){                //arg是返回值,必须是字符串
                var callback_dict = $.parseJSON(arg);
                $('#uname_error').text(callback_dict.username[0].message);
                $('#pwd_error').text(callback_dict.password[0].message);
{#                    console.log(callback_dict.username[0].message)#}
            }
        })
    }
</script>

app01/forms/account.py

1
2
3
4
5
from django import forms
 
class LoginForm(forms.Form):
    username = forms.CharField()
    password = forms.CharField(widget=forms.PasswordInput())

browser

Django--form验证及错误处理的更多相关文章

  1. Django form验证

    # 模版 class LoginForm(forms.Form): # 模版中的元素 user = forms.CharField(min_length=6,error_messages={" ...

  2. [py][mx]django form验证-给db减压

    django form认证-解压db压力 一般系统都需要前后端都验证 前端验证容器逃逸破解,如通过js console口去发 试想如果后端只有db验证,那么前端无论发什么后端都查询一次db,对db压力 ...

  3. 关于django form验证是否用户名已存在

    想通过django的Form模块进行数据库中是否已存在用户名的验证,首先我先调用了数据库用户名字段所有的值,发现是个queryset对象. 随后经过查询后发现queryset查询集对象可以调用list ...

  4. Django form 中文提交 错误

    在文件头部添加 刻解决 import sys reload(sys) sys.setdefaultencoding("utf-8")

  5. Django 进阶篇之 Form验证

    Django Form验证 在实际的生产环境中比如登录和验证的时候,我们一般都使用Jquery+ajax来判断用户的输入是否为空,假如JS被禁用的话,咱们这个认证屏障是不是就消失了呢?(虽然一般不会禁 ...

  6. django的form验证机制

    今天遇到了一个奇怪的问题,django中formview一直返回200,但是却没有执行form_valid方法,然后在其中加了一个form_invalid方法: class StudentRegist ...

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

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

  8. 04: Form 验证用户数据 & 生成html

    目录:Django其他篇 01:Django基础篇 02:Django进阶篇 03:Django数据库操作--->Model 04: Form 验证用户数据 & 生成html 05:Mo ...

  9. [oldboy-django][2深入django]form表单clean_xx, clean完成数据验证+ form错误信息

    form后台生成form里面的Input标签,以及设置Input的属性 # 需求 后台生成form里面的input标签,并设置input标签的属性, class RegisterForm(Form): ...

  10. django form表单验证

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

随机推荐

  1. 抛弃Https让Cas以Http协议提供单点登录服务

    本文环境: 1.apache-tomcat-7.0.50-windows-x86 2.cas-server-3.4.11 3.cas-client-3.2.1 将cas-server-webapp-3 ...

  2. 重温CLR(八 ) 泛型

    熟悉面向对象编程的开发人员都深谙面向对象的好处,其中一个好处是代码重用,它极大提高了开发效率.也就是说,可以派生出一个类,让他继承基类的所有能力.派生类只需要重写虚方法,或添加一些新方法,就可定制派生 ...

  3. Mac 及 Xcode快捷键

    mac快捷键: 窗口最大化:control+command+F 窗口最小化:command+M 关闭当前:    command+W 退出程序:    command+Q Safari往下翻页:空格 ...

  4. is is not == !=之间的区别

    简单来说,python中的is与is not运算符可判断两个对象是否为同一对象.若为同一个对象,则对象1 is 对象2为True .反正,若非同一个对象,则对象1 is not 对象2为True 要理 ...

  5. Django的CSRF机制

    原文链接:http://www.cnblogs.com/lins05/archive/2012/12/02/2797996.html 必须有的是: 1.每次初始化一个项目时,都能看到django.mi ...

  6. Linux多网卡的时候执行机器Ip

    在Linux部署的时候,经常会有多网卡的情况出现,这时候项目又需要指定Ip.在这种情况下,要配置linux机子的host,指定里头要使用的ip地址,否则linux机子不知道去找哪个ip. 一.查看本机 ...

  7. 注册驱动时如何调用probe函数 ?

    platform_driver_register       driver_register             bus_add_driver    //把驱动放入总线的驱动链表里         ...

  8. ARM-Linux内核移植之(一)——内核启动流程分析

    内核版本:2.6.22  为什么要采用这样一个较低的版本进行移植了,因为韦东山大牛说了,低版本的才能学到东西,越是高版本需要移植时做的工作量越少,学的东西越少. 内核启动分为三个阶段,第一是运行hea ...

  9. SQL Server2005中文版x64安装29506错误解决办法

    在使用SQL Server 2005简体中版安装时,使用X86(32位操作系统下)安装没有出现任何问题.可是在X64(64位操作系统下)安装过程没有出现问题,可是安装完成后却没有Microsoft S ...

  10. Python字符串笔录

    python字符串操作实方法,包括了几乎所有常用的python字符串操作,如字符串的替换.删除.截取.复制.连接.比较.查找.分割等 1.去空格及特殊符号 >>> s = '123 ...