Django1.7+JQuery+Ajax集成小例子

Ajax的出现让Web展现了更新的活力,基本所有的语言,都动态支持Ajax与起服务端进行通信,并在页面实现无刷新动态交互。  下面是散仙使用Django+Jquery+Ajax的方式来模拟实现了一个验证用户注册时,用户名存在不存在的一个小应用。注意,验证存在不存在使用的是Ajax的方式,不用让用户点击按钮验证是否存在。  页面HTML代码如下: 

Html代码  

  1. <!DOCTYPE html>   <html>   <head lang="en">       <meta charset="UTF-8">       <title>Ajax验证测试</title>   </head>   <script src="/static/jquery/jquery211.js"></script>   <script>          $(function(){             $("#pu").bind('keydown',function(){              c=$("#pu").val()              $.ajax({                   type:"POST",                   url:"/ccc/",                   data:{name:c},                   dataType:"json",                   success: function(data) {                       $("#p").text(data.msg)                   }               });                })          })         </script>   <body>            输入名字进行校验:<input id="pu" type="text"> <span id="p" style="color: red"></span>      </body>   </html>

view端的代码,注意csrf的装饰方法,针对post请求: 

Python代码  

from django.shortcuts import render  
from django.http.response import HttpResponse  
# Create your views here.  
from django.shortcuts import render_to_response  
#导入render_to_response  
from django.shortcuts import render_to_response  
#导入包装的csrf请求,对跨站攻击脚本做处理  
from django.views.decorators.csrf import csrf_exempt  
  
import json  
  
def tt(request):  
    return  render_to_response('em/add.html')  
  
  
names=list();  
names.append("zhangsa")  
names.append("aa")  
names.append("b")  
names.append("c")  
 
 
@csrf_exempt  
def ccc(request):  
  
    name=request.POST.get("name",None)  
    rtxt="";  
    if name is not None:  
        b=name in names  
        if b:  
            #print("名字已经存在!",name)  
            rtxt="名字已经存在!"  
        else:  
            print("名字不存在!")  
            rtxt="名字不存在!"  
    #print("获取的名字是:NU ",name)  
  
    return  HttpResponse(json.dumps({"msg":rtxt}))

urls里面的代码: 

Python代码  

  1. #ajax校验    url(r'^ccc/$',ccc),

注意里面用到了json.dumps函数来生成json对象,注意词典的形式,在测试之前,最后,先访问一下看看,json数据是否能拿到.  ajax验证没有问题之后,我们就可以在前端进行了,测试效果就是散仙开头所截图,本文的重点在于验证ajax的功能调用,所以并没有直接从数据库里面获取数据进行验证,而是使用了list集合,进行了数据的模拟,如果想做的更完美一点,可以把数据库部分实现,这样就与真实中的网站验证场景就一样了。 

本文参与腾讯云自媒体分享计划,欢迎正在阅读的你也加入,一起分享。

发表于

我来说两句

0 条评论
登录 后参与评论

相关文章

来自专栏黑泽君的专栏

Struts2的下载和安装

  使用Struts2框架,进行Web开发,或者运行Struts2的程序,必须,先下载并安装好Struts2    从Struts2的官网中进行下载  htt...

15920
来自专栏瓜大三哥

HLS Lesson9-c/c++ testbench书写

目的: l验证C函数的正确性 l提高效率 1.main()函数返回0则表明结果是正确的,如果是非0则表明结果是不正确的。 2.输入激励(stimulus) 输入...

288100
来自专栏王磊的博客

nodejs常用组件

mssql 用途:连接SqlServer数据库 node-excel-export 用途:导出excel表格 nodegrass 用途:模拟用户进行get/po...

34860
来自专栏柠檬先生

mybatis——学习笔记

配置文件    <properties resource="dbconfig.properties"></properties>     1. properti...

224100
来自专栏王磊的博客

Ubuntu安装设置nginx和nohup常用操作

nginx安装 Ubuntu直接从常规源中安装 apt-get install nginx 安装的目录 配置文件:/etc/nginx/ 主程序文件:/usr/...

393110
来自专栏从零开始学 Web 前端

从零开始学 Web 之 Ajax(一)服务器相关概念

服务器和客户端都是电脑,在硬件层面上没有明显的划分,配置很差的个人电脑任然可以作为服务器。

15020
来自专栏俗人笔记

Nginx+PHP php文件404错误的一个可能原因

网站本来是nginx + php-fpm socket的方式跑的,nginx是自己编译安装了。昨天尝试把网站加上https,就根据https://certbot...

43430
来自专栏python读书笔记

python 数据分析基础 day7-xlrd,xlwt读写多个excel通过xlrd和xlwt读多个excel文件并写入一个新excel文件

今天总结的内容为通过xlrd和xlwt模块将读取的多个excel文件中多个工作表输出至多个excel文件中。 通过xlrd和xlwt读多个excel文件并写入一...

39380
来自专栏FreeBuf

TEST LAB V8在线渗透实验室教程(三)

这一部分我们将演示渗透Mail和SSH系统 ? 攻击MAIL 当前,我们已经有了Westfall的账号和密码,可以登录它的邮箱,通过浏览其收件箱,我们找到了另外...

22150
来自专栏王磊的博客

Ubuntu安装设置nginx和nohup常用操作

17520

扫码关注云+社区

领取腾讯云代金券