ajax python_Python 之Ajax
1.使用Ajax在后台传递参数的示例要使用Ajax传递参数,需要使用jquery,使用jquery需要注意以下几点。1.建立static的目录,将jquery导入2.在项目s13day18_django的settings配置中,指定jquery的目录,同时注释掉CSRFSTATIC_URL = '/static/'STATICFILES_DIRS=(os.path.join(BASE_DIR,'s
1.使用Ajax在后台传递参数的示例
要使用Ajax传递参数,需要使用jquery,使用jquery需要注意以下几点。
1.建立static的目录,将jquery导入
2.在项目s13day18_django的settings配置中,指定jquery的目录,同时注释掉CSRF
STATIC_URL = '/static/'STATICFILES_DIRS=(
os.path.join(BASE_DIR,'static'),
)
# 'django.middleware.csrf.CsrfViewMiddleware',
3.在app01下面,指定路由关系
urlpatterns =[#url(r'^index/(\d+)/', views.index),
#url(r'^detail/(\d+)/',views.detail),
#url(r'^template/',views.template),
url(r'^extend/',views.extend),
url(r'^assets/',views.assets),
url(r'^userinfo/',views.userinfo),
url(r'^ajax_demo/',views.ajax_demo),
]
4.在app01下面,定义ajax_demo函数
defajax_demo(request):if request.method == 'POST':
user= request.POST.get('user')
pwd= request.POST.get('pwd')print(user,pwd)if user == '111' and pwd == '222':return HttpResponse('1')else:return HttpResponse('2')return render(request,'ajax_demo.html')
5.在templates中,添加关于ajax_demo的HTML信息
用户名:
密码:
$.ajax({
url:'/web/ajax_demo/',
type:'POST',
data:{'user':$('#username').val(),'pwd':$('#pwd').val()},
success:function(data){if(data == '1'){
location.href="http://www.baidu.com";
}else{
alert("用户名或密码错误")
}
}
})
}
整个执行的过程是,ajax传递参数给了函数ajax_demo,函数获取到用户键入的值,然后通过HttpResponse返回给回调函数success,回调函数再执行相应的操作。
==================================================================================================== 但是在实际的使用中,我们要这么定义views.py
importjsondefajax_demo(request):if request.method == 'POST':
ret= {'status':False,'message':''}
user= request.POST.get('user')
pwd= request.POST.get('pwd')print(user,pwd)if user == '111' and pwd == '222':
ret['status'] =TruereturnHttpResponse(json.dumps(ret))else:
ret['message'] = '用户名或密码错误'
returnHttpResponse(json.dumps(ret))return render(request,'ajax_demo.html')
ajax_demo.html
用户名:
密码:
$.ajax({
url:'/web/ajax_demo/',
type:'POST',
data:{'user':$('#username').val(),'pwd':$('#pwd').val()},
dataType:'json',
success:function(data){if(data.status){
location.href="http://www.baidu.com";
}else{
alert(data.message)
}
}
})
}
如果不用ajax自带的dataType类型,也可以自己将json的格式转化为字典格式:
$.ajax({
url:'/web/ajax_demo/',
type:'POST',
data:{'user':$('#username').val(),'pwd':$('#pwd').val()},
{#dataType:'json',#}
success:function(data){
var data_dic=JSON.parse(data);if(data_dic['status']){
location.href="http://www.baidu.com";
}else{
alert(data_dic['message'])
}
}
})
}
JQuery中的ajax也是调用了浏览器中的XMLHttpRequest对象来执行的。
http://www.cnblogs.com/wupeiqi/articles/5703697.html
魔乐社区(Modelers.cn) 是一个中立、公益的人工智能社区,提供人工智能工具、模型、数据的托管、展示与应用协同服务,为人工智能开发及爱好者搭建开放的学习交流平台。社区通过理事会方式运作,由全产业链共同建设、共同运营、共同享有,推动国产AI生态繁荣发展。
更多推荐



所有评论(0)