婷婷综合国产,91蜜桃婷婷狠狠久久综合9色 ,九九九九九精品,国产综合av

主頁 > 知識庫 > Django如何與Ajax交互

Django如何與Ajax交互

熱門標簽:蘇州電銷機器人十大排行榜 溫州旅游地圖標注 荊州云電銷機器人供應商 電信營業廳400電話申請 遼寧400電話辦理多少錢 江蘇房產電銷機器人廠家 幫人做地圖標注收費算詐騙嗎 外呼不封號系統 悟空智電銷機器人6

前后端傳輸數據的編碼格式

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

urlencoded
formdata
json

Ajax提交urlencoded格式數據

Ajax給后臺發送數據的默認編碼格式是urlencoded,比如username=abcdepassword=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后端,請一定注意以下三點:

  1. contentType參數指定成application/json;
  2. 數據是真正的json格式數據;
  3. Django后端不會幫你處理json格式數據需要你自己去request.body獲取并處理。
$("#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)
        }
    });
});

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="/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.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)

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" 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交互的資料請關注腳本之家其它相關文章!

您可能感興趣的文章:
  • Django與AJAX實現網頁動態數據顯示的示例代碼
  • 使用AJAX和Django獲取數據的方法實例
  • Django查詢優化及ajax編碼格式原理解析
  • 淺析Django 接收所有文件,前端展示文件(包括視頻,文件,圖片)ajax請求
  • django ajax發送post請求的兩種方法
  • django框架中ajax的使用及避開CSRF 驗證的方式詳解
  • Django中ajax發送post請求 報403錯誤CSRF驗證失敗解決方案
  • Django結合ajax進行頁面實時更新的例子
  • Django 通過JS實現ajax過程詳解
  • Django利用AJAX技術實現博文實時搜索

標簽:欽州 三沙 景德鎮 喀什 濟南 臺灣 宿遷 黃山

巨人網絡通訊聲明:本文標題《Django如何與Ajax交互》,本文關鍵詞  Django,如何,與,Ajax,交互,;如發現本文內容存在版權問題,煩請提供相關信息告之我們,我們將及時溝通與處理。本站內容系統采集于網絡,涉及言論、版權與本站無關。
  • 相關文章
  • 下面列出與本文章《Django如何與Ajax交互》相關的同類信息!
  • 本頁收集關于Django如何與Ajax交互的相關信息資訊供網民參考!
  • 推薦文章
    婷婷综合国产,91蜜桃婷婷狠狠久久综合9色 ,九九九九九精品,国产综合av
    精品1区2区3区| 亚洲国产成人va在线观看天堂| 亚洲同性同志一二三专区| 一区二区免费视频| 国产在线精品一区二区| 91亚洲精品久久久蜜桃| 日韩一区二区在线播放| 国产精品成人一区二区艾草| 精品亚洲成a人| 久久久久国色av免费看影院| 免费精品视频最新在线| 久久综合狠狠综合久久综合88 | 亚洲一区二区三区四区五区黄 | 亚洲精品国产精华液| 久久久精品国产99久久精品芒果 | 51精品秘密在线观看| 久久久国产精华| 午夜精品国产更新| 国产成人综合在线播放| 精品免费视频.| 国产米奇在线777精品观看| 久久久精品黄色| 91视频91自| 日韩影视精彩在线| 久久久亚洲综合| 在线一区二区三区四区| 久久国产精品免费| ㊣最新国产の精品bt伙计久久| 欧美丝袜丝交足nylons| 精品在线播放午夜| 中文字幕亚洲精品在线观看| 色拍拍在线精品视频8848| 制服丝袜日韩国产| 狠狠色丁香久久婷婷综合丁香| 久久久国际精品| 欧美调教femdomvk| 欧美日本一区二区三区| 国产ts人妖一区二区| 一区二区三区高清| 精品福利在线导航| 高清av一区二区| 午夜在线成人av| 国产精品区一区二区三区| 欧美中文字幕一二三区视频| 青青草伊人久久| 国产精品国产三级国产专播品爱网| 欧美影视一区二区三区| 国产专区综合网| 亚洲成人动漫在线免费观看| 欧美一区二区福利在线| 欧美色网一区二区| 国产一区二区在线影院| 日本亚洲最大的色成网站www| 一区二区在线观看视频在线观看| 久久久蜜桃精品| 精品日韩在线观看| 日本乱码高清不卡字幕| 色综合久久综合| 成人污污视频在线观看| 久久99这里只有精品| 婷婷中文字幕一区三区| 一区二区三区日韩精品视频| 国产片一区二区| 日韩免费看网站| 欧美军同video69gay| 91麻豆国产精品久久| 国产精品一区二区黑丝| 久久91精品久久久久久秒播| 午夜精品久久久久久不卡8050| 亚洲欧美综合在线精品| 中文字幕的久久| 欧美激情一区二区在线| 26uuu国产在线精品一区二区| 欧美日韩免费在线视频| 欧美日韩免费不卡视频一区二区三区| 亚洲愉拍自拍另类高清精品| 有坂深雪av一区二区精品| 国产精品美女视频| 国产精品素人一区二区| 国产精品另类一区| 中文字幕一区视频| 亚洲精品国产品国语在线app| 亚洲精品中文在线影院| 亚洲免费资源在线播放| 中文字幕av一区二区三区高| 久久久久久一二三区| 国产欧美一区二区三区鸳鸯浴| 国产精品国产三级国产a| 国产丝袜欧美中文另类| 国产精品久久久久久久午夜片| 久久先锋影音av| 国产精品视频一二三区| 一区二区在线观看免费| 午夜精品一区二区三区电影天堂| 欧美aaa在线| 成人中文字幕电影| 欧美日韩精品欧美日韩精品一| 欧美一级夜夜爽| 久久网站最新地址| 日本一区二区不卡视频| 亚洲欧美日韩国产一区二区三区| 亚洲午夜在线视频| 日韩精品一区第一页| 国产精品99久久久久久有的能看| 成人激情午夜影院| 91精品国产综合久久福利软件| 日韩精品一区二区三区swag | 日韩欧美在线综合网| 欧美大白屁股肥臀xxxxxx| www国产精品av| 亚洲一区二区欧美日韩| 另类小说综合欧美亚洲| 欧美亚洲国产一区二区三区va | 成人性生交大片免费看中文| 91蝌蚪porny九色| 亚洲精品视频在线| 久久国产尿小便嘘嘘| 99在线精品观看| 欧美电影精品一区二区| 国产精品久久久久久久久免费樱桃| 亚洲自拍都市欧美小说| 国产做a爰片久久毛片| 欧美日韩国产首页| 中文字幕亚洲精品在线观看| 午夜欧美视频在线观看| 色综合天天综合在线视频| 国产性色一区二区| 狠狠狠色丁香婷婷综合激情| 欧美亚洲高清一区| 一区二区三区四区高清精品免费观看| 成人性生交大片免费看中文| 久久久久久夜精品精品免费| 日韩avvvv在线播放| 在线播放欧美女士性生活| 亚洲成人午夜电影| 91麻豆精品国产自产在线观看一区| 亚洲资源中文字幕| 99re成人精品视频| 欧美国产成人在线| 国产成人精品影院| 久久精品人人做人人综合| 国产一区二区三区免费看| 欧美大片在线观看| 石原莉奈在线亚洲二区| 精品视频一区二区不卡| 亚洲国产成人高清精品| 欧美亚洲国产一区在线观看网站| 一二三四社区欧美黄| 欧美在线free| 日韩成人av影视| 精品国产乱码久久久久久夜甘婷婷| 国产一区二区不卡在线| 欧美国产禁国产网站cc| 色综合av在线| 婷婷久久综合九色综合绿巨人 | 精品国产精品网麻豆系列| 狠狠色狠狠色综合系列| 国产亚洲一区二区三区四区| 高清beeg欧美| 综合自拍亚洲综合图不卡区| 91在线码无精品| 午夜精品久久一牛影视| 欧美一区二区三区免费视频 | 日韩写真欧美这视频| 国产在线播放一区三区四| 日本一区二区三区电影| 一本一道久久a久久精品综合蜜臀| 亚洲国产成人va在线观看天堂| 精品免费一区二区三区| 色综合天天综合在线视频| 色88888久久久久久影院野外| 亚洲成人在线网站| 久久一留热品黄| 色婷婷av一区二区三区之一色屋| 天天操天天色综合| 国产精品人妖ts系列视频| 在线观看区一区二| 国产一区三区三区| 亚洲一区二区三区在线播放| 欧美成人一区二区三区片免费| 国产成人av影院| 亚洲一区二区三区四区五区黄 | 678五月天丁香亚洲综合网| 国产精品亚洲第一| 天天色天天爱天天射综合| 国产精品美女久久久久久久| 欧美日本国产视频| 国产乱理伦片在线观看夜一区| 午夜精品久久久| 国产精品久久久一本精品 | 精品国产123| 欧美色涩在线第一页| 波多野结衣的一区二区三区| 裸体在线国模精品偷拍| 亚洲一区二区精品3399| 中文字幕巨乱亚洲| 国产午夜精品久久久久久免费视 | 欧美色爱综合网| 免费欧美日韩国产三级电影| 亚洲欧美日韩综合aⅴ视频|