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

news/2024/7/11 1:19:19 标签: ajax, django, jquery, json, python
Ajax的出现让Web展现了更新的活力,基本所有的语言,都动态支持Ajax与起服务端进行通信,并在页面实现无刷新动态交互。


下面是散仙使用Django+Jquery+Ajax的方式来模拟实现了一个验证用户注册时,用户名存在不存在的一个小应用。注意,验证存在不存在使用的是Ajax的方式,不用让用户点击按钮验证是否存在。

截图如下:

[img]http://dl2.iteye.com/upload/attachment/0102/3707/f3eb0064-ce51-3087-ab2f-1e39ae5ef967.png[/img]

[img]http://dl2.iteye.com/upload/attachment/0102/3711/4364c2b5-7858-3e9f-9b49-96bc226c35bf.png[/img]


页面HTML代码如下:

<!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">   #ajax校验
url(r'^ccc/$',ccc),



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


[img]http://dl2.iteye.com/upload/attachment/0102/3719/23d99cd2-e127-32dc-a07c-72706465efa5.png[/img]


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

http://www.niftyadmin.cn/n/789449.html

相关文章

2012届华为校园招聘机试题

1、选秀节目打分&#xff0c;分为专家评委和大众评委&#xff0c;score[] 数组里面存储每个评委打的分数&#xff0c;judge_type[] 里存储与 score[] 数组对应的评委类别&#xff0c;judge_type[i] 1&#xff0c;表示专家评委&#xff0c;judge_type[i] 2&#xff0c;表示大众…

Cloudera公司首席架构师Doug Cutting谈Hadoop之变迁

Doug Cutting是开源界的大神&#xff0c;也是散仙非常膜拜的一个对象&#xff0c;从最早2000年Lucene的开始&#xff0c;到后来的基于Lucene衍生的企业级搜索项目Solr和ElasticSearch&#xff0c;以及发展到现在专职于全网采集的Nutch项目&#xff0c;再到后来从Nutch项目里&am…

HTTP和HTTPS简单介绍(TCP三次握手四次挥手和TLS 2或4 次握手)

这里只是让自己更好的理解HTTP和HTTPS的区别&#xff0c;HTTPS在HTTP的基础上做了什么&#xff0c;介绍也非常简单&#xff0c;大家可以去看HTTP 与 HTTPS 的区别 &#xff0c;下面很多图也是复制上面链接的 文章目录0、HTTP请求在网络七层协议中如何传输的(1)七层、五层和四层…

java提供的四种线程池和自定义创建线程池

可以直接看java线程池使用最全详解我这下面的是做笔记用的&#xff0c;可能会忽略很多细节 文章目录0、ThreadPoolExecutor构造函数中参数的说明1、java提供的四种线程池如何使用(1)newCachedThreadPool(无核心线程&#xff0c;空闲线程60s销毁&#xff0c;无上限数量)(2)newFi…

Hadoop集群搭建完毕后,如何测试是否正常工作?

最近&#xff0c;要在沙箱的环境装一个hadoop的集群&#xff0c;用来建索引所需&#xff0c;装hadoop已经没啥难的了&#xff0c;后面&#xff0c;散仙会把重要的配置信息&#xff0c;贴出来&#xff0c;本次装的hadoop版本是hadoop1.2的版本&#xff0c;如果不知道怎么装的&am…

网新恒天2013年校园招聘笔试

转载请标明出处&#xff0c;原文地址&#xff1a;http://blog.csdn.net/hackbuteer1/article/details/11194703 一、英语 1、请将以下短文翻译成英文 电子商务是基于计算机技术、网络技术和远程通信技术&#xff0c;实现买卖双方不谋面地进行各种商贸活动&#xff0c;比如产品和…

jQuery整理笔记文件夹

jQuery整理笔记文件夹 jQuery整理笔记一----jQuery開始 jQuery整理笔记二----jQuery选择器整理 jQuery整理笔记三----jQuery过滤函数 jQuery整理笔记四----jQuery操作DOM jQuery整理笔记五----jQuery事件 jQuery整理笔记六----jQuery动画 jQuery整理笔记七----几个经典表单应用…

hadoop集群警告No groups available for user dr.who

刚装完的hadoop集群&#xff0c;在查看namenode的log时&#xff0c;散仙发现有如下的警告信息&#xff1a;2014-10-30 16:49:18,340 INFO org.apache.hadoop.hdfs.StateChange: STATE* Leaving safe mode after 2 secs2014-10-30 16:49:18,340 INFO org.apache.hadoop.hdfs.Sta…