django与ajax怎样实现交互?一文带你看懂
Admin 2021-08-27 群英技术资讯 399 次浏览
这篇文章给大家分享的是有关django与ajax怎样实现交互的内容,很多新手django与ajax交互可能不是很了解,因此分享给大家做个参考,有这方面学习需要的朋友接下来一起跟随小编看看吧。
前后端传输数据的编码格式主要有三种, 本文接下来将详细演示。
urlencoded formdata json
Ajax给后台发送数据的默认编码格式是urlencoded,比如username=abcde&password=123456的形式。Django后端拿到符合urlencoded编码格式的数据都会自动帮你解析分装到request.POST中,与form表单提交的数据相同。
下面两种方式是等同的。
//手动构造数据data $("#btnSubmit").click(function () { $.ajax({ url: '/auth/', //也可以反向解析{% url 'login' %} type: 'post', data: { 'username': $("#id_username").val(), 'password': $('#id_password').val() }, success: function (data){ } }); }; // .serialize() 方法可将<input>, <textarea> 以及 <select>表单序列化 // 成urlencoded格式数据 $("#btnSubmit").click(function () { let data = $("#loginForm").serialize(); $.ajax({ url: "/auth/", //别忘了加斜杠 type: $("#loginForm").attr('method'), data: data, success: function (data) { } }); });
Ajax上传文件需要借助于js内置对象FormData,另外上传文件时表单千万别忘了加enctype="multipart/form-data"属性。
//案例1,点击submi上传文件 $("#submitFile").click(function () { let formData = new FormData($("#upload-form")); $.ajax({ url:"/upload/",//也可以写{% url 'upload' %} type:"post", data:formData, //这两个要必须写 processData:false, //不预处理数据 因为FormData 已经做了 contentType:false, //不指定编码了 因为FormData 已经做了 success:function(data){ console.log(data); } }); }); //案例2,同时上传文件并提交其它数据 $("#submitFile").click(function () { //js取到文件 let myfile = $("#id_file")[0].files[0]; //生成一个FormData对象 let formdata = new FormData(); //加值 formdata.append('name', $("#id_name").val()); //加文件 formdata.append('myfile', myfile); $.ajax({ url: '/upload/', //url别忘了加/杠 type: 'post', //这两个要必须写 processData:false, //不预处理数据 因为FormData 已经做了 contentType:false, //不指定编码了 因为FormData 已经做了 data: formdata, success: function (data) { console.log(data); } }); });
前后端传输数据的时候一定要确保声明的编码格式跟数据真正的格式是一致的。如果你通过Ajax发送Json格式数据给Django后端,请一定注意以下三点:
$("#submitBtn").click(function () { var data_obj={'name':'abcdef','password':123456};//Javascript对象 $.ajax({ url:'', type:'post', contentType:'application/json', //一定要指定格式 contentType data:JSON.stringify(data_obj), //转换成json字符串格式 success:function (data) { console.log(data) } }); });
// 第一种方式直接在发送数据中加入csrfmiddlewaretoken $("#btn").on("click",function () { $.ajax({ url:"/some_url/", type:"POST", data:{ csrfmiddlewaretoken: {{ csrf_token }}, //写在模板中,才会被渲染 }, success:function (data) { } }); }); //通过jquery选择器获取csrfmiddlewaretoken $("#btn").on("click",function () { $.ajax({ url:"/some_url/", type:"POST", data:{ csrfmiddlewaretoken:$('[name="csrfmiddlewaretoken"]').val(), }, success:function (data) { } }); }); //使用jquery.cookie.js调用请求头cookie中的csrftoken <script src="/static/jquery.cookie.js"> <script> $("#btn").on("click",function () { $.ajax({ url:"/some_url/", type:"POST", headers:{"X-CSRFToken":$.cookie('csrftoken')}, data:$("#form1").serialize() }); }) </script>
联动下拉菜单是Web开发中一个被经常使用的应用。比如当你从一个列表从选择一个国家的时候,联动下拉菜单会同步显示属于该国家所有城市列表供用户选择。今天我们就教你如何使用Django+Ajax生成联动下拉菜单。
我们的模型如下所示:
class Country(models.Model): name = models.CharField(verbose_name="国家", max_length=50) def __str__(self): return self.name class City(models.Model): name = models.CharField(verbose_name="城市", max_length=50) country = models.ForeignKey(Country, on_delete=models.CASCADE, verbose_name="国家",) def __str__(self): return self.name
我们的模板如下所示,表单中对应国家和城市下拉菜单的DOM元素id分别为id_country和id_city。当用户选择国家后,ajax会携带国家的id值向后台发送请求获得当前国家的所有城市清单,并在前端渲染显示。
{% block content %} <h2>创建用户 - 联动下拉菜单</h2> <form method="post" class="form-horizontal" role='form' action=""> {% csrf_token %} {{ form.as_p }} <button type="submit" class="btn btn-primary">Submit</button> </form> {% endblock %} <script src="https://code.jquery.com/jquery-3.1.0.min.js"></script> <script> $("#id_country").change(function() { var country_id = $(this).val(); $.ajax({ url: '/ajax/load_cities/', data: { 'country_id': country_id }, type: 'GET', dataType: 'json', success: function (data) { var content=''; $.each(data, function(i, item){ content+='<option value='+item.id+'>'+item.name+'</option>' }); $('#id_city').html(content) }, }); }); </script>
Django负责处理视图Ajax请求的视图函数如下所示:
def ajax_load_cities(request): if request.method == 'GET': country_id = request.GET.get('country_id', None) if country_id: data = list(City.objects.filter(country_id=country_id).values("id", "name")) return JsonResponse(data, safe=False)
前端模板及js文件如下所示, 请注意我们是如何在表单中加入了enctype属性,如何使用FormData上传文件,并解决了csrftoken问题的。
{% block content %} <form action="" method="post" enctype="multipart/form-data" id="form"> <ul class="errorlist"></ul> {% csrf_token %} {{ form.as_p }} <input type="button" class="btn btn-info form-control" value="submit" id="btn" /> </form> <table class="table table-striped" id="result"> </table> {% endblock %} {% block js %} <script src=" https://cdn.jsdelivr.net/jquery.cookie/1.4.1/jquery.cookie.min.js "> </script> <script> var csrftoken = $.cookie('csrftoken'); function csrfSafeMethod(method) { return (/^(GET|HEAD|OPTIONS|TRACE)$/.test(method)); } $(document).ready(function(){ $('#btn').click(function(e){ e.preventDefault(); // 构建FormData对象 var form_data = new FormData(); form_data.append('file', $('#id_file')[0].files[0]); $.ajax({ url: '/file/ajax_upload/', data: form_data, type: 'POST', dataType: 'json', // 告诉jQuery不要去处理发送的数据, 发送对象。 processData : false, // 告诉jQuery不要去设置Content-Type请求头 contentType : false, // 获取POST所需的csrftoken beforeSend: function(xhr, settings) { if (!csrfSafeMethod(settings.type) && !this.crossDomain) { xhr.setRequestHeader("X-CSRFToken", csrftoken); }}, success: function (data) { if(data['error_msg']) { var content = '<li>'+ data['error_msg'] + '</li>'; $('ul.errorlist').html(content); } else { var content= '<thead><tr>' + '<th>Name and URL</th>' + '<th>Size</th>' + '</tr></thead><tbody>'; $.each(data, function(i, item) { content = content + '<tr><td>' + "<a href= ' " + item['url'] + " '> " + item['url'] + '</a></td><td>' + item['size'] + '</td><td><tr>' }); content = content + "</tbody>"; $('#result').html(content); } }, }); }); }); </script> {% endblock %}
Django负责处理视图Ajax请求的视图函数如下所示:
# handling AJAX requests def ajax_upload(request): if request.method == "POST": form = FileUploadModelForm(data=request.POST, files=request.FILES) if form.is_valid(): form.save() # Obtain the latest file list files = File.objects.all().order_by('-id') data = [] for file in files: data.append({ "url": file.file.url, "size": filesizeformat(file.file.size), }) return JsonResponse(data, safe=False) else: data = {'error_msg': "Only jpg, pdf and xlsx files are allowed."} return JsonResponse(data) return JsonResponse({'error_msg': 'only POST method accpeted.'})
关于django与ajax交互就介绍到这,上述实例具有一定的参考价值,感兴趣的朋友可以参考学习,希望能对大家有帮助,想要了解更多django与ajax交互的相关内容,大家可以关注其他文章。
文本转载自脚本之家
免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:mmqy2019@163.com进行举报,并提供相关证据,查实之后,将立刻删除涉嫌侵权内容。
猜你喜欢
Python内置函数-pow() 函数。内置和math模板都有pow() 函数,下面分别详细讲解。
这篇文章主要介绍了解决Python保存文件名太长OSError: [Errno 36] File name too lon问题,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
接触过Java的朋友对于类应该不陌生,我们在学习python过程中,也会学习到类,那么python的类如何理解?很多新手学习python时,可能对此比较困惑。对此,下面小编就给大家介绍一下python的类以及使用。感兴趣的朋友就继续往下看吧。
Python中字符串反转常用的五种方法:使用字符串切片、使用递归、使用列表reverse()方法、使用栈和使用for循环。
这篇文章主要为大家介绍了Python random模块的运用,具有一定的参考价值,感兴趣的小伙伴们可以参考一下,希望能够给你带来帮助<BR>
成为群英会员,开启智能安全云计算之旅
立即注册Copyright © QY Network Company Ltd. All Rights Reserved. 2003-2020 群英 版权所有
增值电信经营许可证 : B1.B2-20140078 粤ICP备09006778号 域名注册商资质 粤 D3.1-20240008