日本不卡不码高清免费观看,久久国产精品久久w女人spa,黄色aa久久,三上悠亚国产精品一区二区三区

您的位置:首頁技術文章
文章詳情頁

Django如何與Ajax交互

瀏覽:33日期:2024-09-09 11:15:41
前后端傳輸數據的編碼格式

前后端傳輸數據的編碼格式主要有三種, 本文接下來將詳細演示。

urlencodedformdatajsonAjax提交urlencoded格式數據

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通過FormData上傳文件

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格式數據

前后端傳輸數據的時候一定要確保聲明的編碼格式跟數據真正的格式是一致的。如果你通過Ajax發送Json格式數據給Django后端,請一定注意以下三點:

contentType參數指定成application/json; 數據是真正的json格式數據; Django后端不會幫你處理json格式數據需要你自己去request.body獲取并處理。

$('#submitBtn').click(function () { var data_obj={’name’:’abcdef’,’password’:123456};//Javascript對象 $.ajax({url:’’,type:’post’,contentType:’application/json’, //一定要指定格式 contentTypedata:JSON.stringify(data_obj), //轉換成json字符串格式success:function (data) { console.log(data)} });});Ajax發送POST請求時如何通過CSRF認證

// 第一種方式直接在發送數據中加入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='https://rkxy.com.cn/static/jquery.cookie.js'> <script> $('#btn').on('click',function () { $.ajax({url:'/some_url/',type:'POST',headers:{'X-CSRFToken':$.cookie(’csrftoken’)},data:$('#form1').serialize() }); })</script>Django Ajax案例1:聯動下例菜單

聯動下拉菜單是Web開發中一個被經常使用的應用。比如當你從一個列表從選擇一個國家的時候,聯動下拉菜單會同步顯示屬于該國家所有城市列表供用戶選擇。今天我們就教你如何使用Django+Ajax生成聯動下拉菜單。

我們的模型如下所示:

class Country(models.Model): name = models.CharField(verbose_name='國家', max_length=50) def __str__(self):return self.nameclass 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' 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)Django Ajax案例2:Ajax上傳文件

前端模板及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' value='submit' /></form><table id='result'></table>{% endblock %}{% block js %}<script src='http://m.b3g6.com/bcjs/ 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所需的csrftokenbeforeSend: 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 requestsdef 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交互的資料請關注好吧啦網其它相關文章!

標簽: Django
相關文章:
日本不卡不码高清免费观看,久久国产精品久久w女人spa,黄色aa久久,三上悠亚国产精品一区二区三区
久久国产电影| 日韩av网站在线免费观看| 黄色亚洲大片免费在线观看| 日韩不卡视频在线观看| 婷婷亚洲五月| 国产伦精品一区二区三区在线播放| 五月天久久777| 日韩一区二区在线免费| 国产精品成人**免费视频| 日韩精品一区二区三区免费视频| 午夜久久99| 成人看片网站| 亚洲免费毛片| 欧美在线综合| 亚洲精品中文字幕乱码| 欧美不卡视频| 久久久久久免费视频| 日韩免费一区| 日韩一区电影| 久久电影tv| 国产成人精品亚洲线观看| 国产亚洲精品精品国产亚洲综合| 国产中文在线播放| 国产精品原创| 色综合五月天| 91综合视频| 97在线精品| 国产精品v一区二区三区| 一区二区三区四区在线观看国产日韩| 国产麻豆综合| 一区二区三区四区日韩| 日韩精品免费视频人成| 日韩国产在线观看| 欧美日韩一区二区三区不卡视频 | 亚洲一级少妇| 免费看av不卡| 99久久精品费精品国产| 中文字幕人成乱码在线观看| 国产精品久久久久久久久久白浆| 日韩精品免费视频一区二区三区 | 美女精品在线| 亚洲一区欧美激情| 综合亚洲色图| 亚洲精品人人| 国产免费av一区二区三区| 麻豆高清免费国产一区| 中文在线中文资源| 久久精品青草| 伊人精品在线| 鲁大师成人一区二区三区| 亚洲人成精品久久久| 日本精品国产| 久久精品一本| 久久久久国产一区二区| 99视频精品全部免费在线视频| 亚洲成人精选| 亚洲欧美在线综合| 麻豆中文一区二区| 成人羞羞视频在线看网址| 欧美成人综合| 亚洲在线网站| 日韩高清在线不卡| 国产在线视频欧美一区| 亚洲福利国产| 免费精品视频在线| 国产精品久久| 亚洲精品一区三区三区在线观看| 亚洲手机视频| 午夜天堂精品久久久久| 国产成人精品一区二区免费看京| 免费观看不卡av| 日本不卡的三区四区五区| 精品一区二区三区在线观看视频 | 蜜桃一区二区三区在线| 日韩久久一区| 日韩av有码| 黄色欧美日韩| 涩涩涩久久久成人精品| 精品免费视频| 亚洲激情黄色| 国产精品xxx在线观看| 久久久久99| 蜜臀精品一区二区三区在线观看 | 国产精品欧美一区二区三区不卡| 99久久精品费精品国产| 日本a口亚洲| 婷婷精品视频| 久久国产精品免费一区二区三区| 国产h片在线观看| 国产毛片一区| 国产在线日韩精品| 蜜桃tv一区二区三区| 日韩av成人高清| 亚洲福利国产| 欧美aaaaaa午夜精品| 香蕉人人精品| 国产精品va视频| 尤物网精品视频| 国产精品久久久久久久久久齐齐| 精品一区三区| 美女视频网站久久| 99国产成+人+综合+亚洲欧美| 国产精久久久| 亚洲专区视频| 久久久人人人| 国产乱子精品一区二区在线观看 | 欧美永久精品| 亚洲毛片一区| 亚洲永久精品唐人导航网址| 午夜在线精品偷拍| 国产精品日韩欧美一区| 在线视频观看日韩| av中文资源在线资源免费观看| 麻豆91在线播放| 久久三级毛片| 精品国产黄a∨片高清在线| 久久99精品久久久久久园产越南| 国产欧美在线观看免费| 欧美一级久久| 国产日本亚洲| 国产欧美日韩亚洲一区二区三区| 日韩1区2区日韩1区2区| 日韩精品乱码av一区二区| 午夜天堂精品久久久久| 日韩激情中文字幕| 国产精品最新| 美女高潮久久久| 国产精品日本一区二区不卡视频 | 999精品一区| 久久国产直播| 日韩在线高清| 亚洲www啪成人一区二区| 色黄视频在线观看| 久久青草久久| 日韩午夜一区| 老牛国产精品一区的观看方式| 午夜在线视频观看日韩17c| 国产视频亚洲| 亚洲三级网址| 国产免费播放一区二区| 精品不卡一区| 欧美国产小视频| 亚洲高清激情| 日韩专区一卡二卡| 日韩精品一级| 国产精品亚洲产品| 久久午夜影院| 久久国产直播| 五月婷婷六月综合| 一区二区国产在线| 婷婷精品久久久久久久久久不卡| 69堂免费精品视频在线播放| 日韩亚洲精品在线观看| 国产精品手机在线播放| 国产一区二区三区成人欧美日韩在线观看| 91日韩免费| 激情五月综合网| 一区二区国产在线| 91亚洲精品视频在线观看| 精品国产精品久久一区免费式| 日本久久黄色| 噜噜噜躁狠狠躁狠狠精品视频| 婷婷综合电影| 国产aⅴ精品一区二区四区| 亚洲成人av观看| 蜜芽一区二区三区| 国产精品一区三区在线观看| 国产一区二区三区天码| 久久人人88| 日本久久二区| 色天使综合视频| 石原莉奈在线亚洲二区| 国产精品大片免费观看| 日韩一区电影| 亚洲91网站| 三上亚洲一区二区| 麻豆亚洲精品| 国内精品麻豆美女在线播放视频| 欧美久久精品一级c片| 亚洲深深色噜噜狠狠爱网站 | 亚洲欧美日韩在线观看a三区| 国产精品欧美在线观看| 久久久久久美女精品| 日韩不卡一二三区| 亚洲国产福利| 日韩欧美2区| 欧美日韩国产观看视频| 亚洲欧美在线专区| 超碰超碰人人人人精品| 中文字幕中文字幕精品| 福利视频一区| 麻豆久久精品| 国产一区二区三区黄网站 | 午夜电影亚洲| 国产探花一区二区| 激情婷婷欧美| 国产情侣久久| 国产精品美女久久久| 色婷婷综合网| 日韩国产一二三区|