Django1.7 + JQuery + Ajax验证用户注册集成小例子

  

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

  

癉jango1.7

  

癉jango1.7

  

页面HTML代码如下:

        & lt; !DOCTYPE html>   & lt; html>   & lt;头lang=癳n”比;   & lt;元charset=皍tf - 8”比;   & lt; title> Ajax验证测试& lt;/title>   & lt;/head>   & lt;脚本src=" https://www.yisu.com/static/jquery/jquery211.js "祝辞& lt;/script>   & lt; script>   $(函数(){   $ (" # pu ") .bind (keydown,函数(){   c=$ (" # pu ") .val ()   . ajax({美元   类型:“文章”,   url:“/ccc/?   数据:{名称:c},   数据类型:“json”,   成功:功能(数据){   $ (" # p ")。text (data.msg)   }   });   })   })   & lt;/script>   & lt; body>   输入名字进行校验:& lt;输入id=皃u”类型=拔谋尽北?& lt;跨度id=皃”祝辞& lt;/span>   & lt;/body>   & lt;/html>      

视图端的代码,注意csrf的装饰方法,针对帖子请求:

        django。快捷方式进口呈现   从django.http。响应进口HttpResponse   #创建你的观点。   django。快捷方式进口render_to_response   #导入render_to_response   django。快捷方式进口render_to_response   #导入包装的csrf请求,对跨站攻击脚本做处理   从django.views.decorators.csrf进口csrf_exempt      进口json      def tt(请求):   返回render_to_response (' em/add.html ')         列表名称=();   names.append (“zhangsa”)   names.append (“aa”)   names.append (“b”)   names.append (“c”)         @csrf_exempt   def ccc(请求):      name=request.POST.get(“名字”,没有一个)   rtxt=" ";   如果名字不是没有:   b=名字的名字   如果b:   #打印(“名字已经存在!”,名称)   rtxt="名字已经存在!”   其他:   打印(“名字不存在!”)   rtxt="名字不存在!”   #打印(“获取的名字是:ν”,名称)      返回HttpResponse (json.dumps({“味精”:rtxt}))      

url里面的代码:

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

注意里面用到了json.dumps函数来生成json对象,注意词典的形式,在测试之前,最后,先访问一下看看,json数据是否能拿的到。

  

癉jango1.7

  

ajax验证没有问题之后,我们就可以在前端进行了,测试效果就是散仙开头所截的图,本文的重点在于验证ajax的功能调用,所以并没有直接从数据库里面获取数据进行验证,而是使用了集列表合,进行了数据的模拟,如果想做的更完美一点,可以把数据库部分实现,这样就与真实中的网站验证场景就一样了。
  

Django1.7 + JQuery + Ajax验证用户注册集成小例子