ajax python_Python 之Ajax

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

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值