成人性生交大片免费看视频r_亚洲综合极品香蕉久久网_在线视频免费观看一区_亚洲精品亚洲人成人网在线播放_国产精品毛片av_久久久久国产精品www_亚洲国产一区二区三区在线播_日韩一区二区三区四区区区_亚洲精品国产无套在线观_国产免费www

主頁(yè) > 知識(shí)庫(kù) > Django如何與Ajax交互

Django如何與Ajax交互

熱門(mén)標(biāo)簽:蘇州電銷(xiāo)機(jī)器人十大排行榜 溫州旅游地圖標(biāo)注 荊州云電銷(xiāo)機(jī)器人供應(yīng)商 電信營(yíng)業(yè)廳400電話申請(qǐng) 遼寧400電話辦理多少錢(qián) 江蘇房產(chǎn)電銷(xiāo)機(jī)器人廠家 幫人做地圖標(biāo)注收費(fèi)算詐騙嗎 外呼不封號(hào)系統(tǒng) 悟空智電銷(xiāo)機(jī)器人6

前后端傳輸數(shù)據(jù)的編碼格式

前后端傳輸數(shù)據(jù)的編碼格式主要有三種, 本文接下來(lái)將詳細(xì)演示。

urlencoded
formdata
json

Ajax提交urlencoded格式數(shù)據(jù)

Ajax給后臺(tái)發(fā)送數(shù)據(jù)的默認(rèn)編碼格式是urlencoded,比如username=abcdepassword=123456的形式。Django后端拿到符合urlencoded編碼格式的數(shù)據(jù)都會(huì)自動(dòng)幫你解析分裝到request.POST中,與form表單提交的數(shù)據(jù)相同。

下面兩種方式是等同的。

//手動(dòng)構(gòu)造數(shù)據(jù)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格式數(shù)據(jù)
                      
$("#btnSubmit").click(function () {
    let data = $("#loginForm").serialize();
    $.ajax({
        url: "/auth/", //別忘了加斜杠
        type: $("#loginForm").attr('method'),
        data: data,
        success: function (data) {
         
        }
    });
}); 

Ajax通過(guò)FormData上傳文件

Ajax上傳文件需要借助于js內(nèi)置對(duì)象FormData,另外上傳文件時(shí)表單千萬(wàn)別忘了加enctype="multipart/form-data"屬性。

//案例1,點(diǎn)擊submi上傳文件
$("#submitFile").click(function () {
    let formData = new FormData($("#upload-form"));
    $.ajax({
       url:"/upload/",//也可以寫(xiě){% url 'upload' %}
       type:"post",
       data:formData,
       //這兩個(gè)要必須寫(xiě)
       processData:false,  //不預(yù)處理數(shù)據(jù)  因?yàn)镕ormData 已經(jīng)做了
       contentType:false,  //不指定編碼了 因?yàn)镕ormData 已經(jīng)做了
       success:function(data){
             console.log(data);
       }
    });
});
                       
//案例2,同時(shí)上傳文件并提交其它數(shù)據(jù)
$("#submitFile").click(function () {
    //js取到文件
    let myfile = $("#id_file")[0].files[0];
    //生成一個(gè)FormData對(duì)象
    let formdata = new FormData();
    //加值
    formdata.append('name', $("#id_name").val());
    //加文件
    formdata.append('myfile', myfile);
    $.ajax({
        url: '/upload/', //url別忘了加/杠
        type: 'post',
        //這兩個(gè)要必須寫(xiě)
        processData:false,  //不預(yù)處理數(shù)據(jù)  因?yàn)镕ormData 已經(jīng)做了
        contentType:false,  //不指定編碼了 因?yàn)镕ormData 已經(jīng)做了
        data: formdata,
        success: function (data) {
            console.log(data);
        }
    });
}); 

Ajax提交Json格式數(shù)據(jù)

前后端傳輸數(shù)據(jù)的時(shí)候一定要確保聲明的編碼格式跟數(shù)據(jù)真正的格式是一致的。如果你通過(guò)Ajax發(fā)送Json格式數(shù)據(jù)給Django后端,請(qǐng)一定注意以下三點(diǎn):

  1. contentType參數(shù)指定成application/json;
  2. 數(shù)據(jù)是真正的json格式數(shù)據(jù);
  3. Django后端不會(huì)幫你處理json格式數(shù)據(jù)需要你自己去request.body獲取并處理。
$("#submitBtn").click(function () {
    var data_obj={'name':'abcdef','password':123456};//Javascript對(duì)象
    $.ajax({
        url:'',
        type:'post',
        contentType:'application/json',  //一定要指定格式 contentType
        data:JSON.stringify(data_obj),    //轉(zhuǎn)換成json字符串格式
        success:function (data) {
            console.log(data)
        }
    });
});

Ajax發(fā)送POST請(qǐng)求時(shí)如何通過(guò)CSRF認(rèn)證

// 第一種方式直接在發(fā)送數(shù)據(jù)中加入csrfmiddlewaretoken
$("#btn").on("click",function () {
    $.ajax({
        url:"/some_url/",
        type:"POST",
        data:{
            csrfmiddlewaretoken: {{ csrf_token }}, //寫(xiě)在模板中,才會(huì)被渲染
        },
        success:function (data) {
    }
});
});
 
//通過(guò)jquery選擇器獲取csrfmiddlewaretoken
$("#btn").on("click",function () {
    $.ajax({
        url:"/some_url/",
        type:"POST",
        data:{
            csrfmiddlewaretoken:$('[name="csrfmiddlewaretoken"]').val(),
        },
        success:function (data) {
            
        }
    });
});
 
//使用jquery.cookie.js調(diào)用請(qǐng)求頭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:聯(lián)動(dòng)下例菜單

聯(lián)動(dòng)下拉菜單是Web開(kāi)發(fā)中一個(gè)被經(jīng)常使用的應(yīng)用。比如當(dāng)你從一個(gè)列表從選擇一個(gè)國(guó)家的時(shí)候,聯(lián)動(dòng)下拉菜單會(huì)同步顯示屬于該國(guó)家所有城市列表供用戶(hù)選擇。今天我們就教你如何使用Django+Ajax生成聯(lián)動(dòng)下拉菜單。

我們的模型如下所示:

class Country(models.Model):
    name = models.CharField(verbose_name="國(guó)家", 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="國(guó)家",)

    def __str__(self):
        return self.name

我們的模板如下所示,表單中對(duì)應(yīng)國(guó)家和城市下拉菜單的DOM元素id分別為id_country和id_city。當(dāng)用戶(hù)選擇國(guó)家后,ajax會(huì)攜帶國(guó)家的id值向后臺(tái)發(fā)送請(qǐng)求獲得當(dāng)前國(guó)家的所有城市清單,并在前端渲染顯示。

{% block content %}
h2>創(chuàng)建用戶(hù) - 聯(lián)動(dòng)下拉菜單/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負(fù)責(zé)處理視圖Ajax請(qǐng)求的視圖函數(shù)如下所示:

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文件如下所示, 請(qǐng)注意我們是如何在表單中加入了enctype屬性,如何使用FormData上傳文件,并解決了csrftoken問(wèn)題的。

{% 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();
        // 構(gòu)建FormData對(duì)象
        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不要去處理發(fā)送的數(shù)據(jù), 發(fā)送對(duì)象。
        processData : false,
        // 告訴jQuery不要去設(shè)置Content-Type請(qǐng)求頭
        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負(fù)責(zé)處理視圖Ajax請(qǐng)求的視圖函數(shù)如下所示:

# 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交互的詳細(xì)內(nèi)容,更多關(guān)于Django與Ajax交互的資料請(qǐng)關(guān)注腳本之家其它相關(guān)文章!

您可能感興趣的文章:
  • Django與AJAX實(shí)現(xiàn)網(wǎng)頁(yè)動(dòng)態(tài)數(shù)據(jù)顯示的示例代碼
  • 使用AJAX和Django獲取數(shù)據(jù)的方法實(shí)例
  • Django查詢(xún)優(yōu)化及ajax編碼格式原理解析
  • 淺析Django 接收所有文件,前端展示文件(包括視頻,文件,圖片)ajax請(qǐng)求
  • django ajax發(fā)送post請(qǐng)求的兩種方法
  • django框架中ajax的使用及避開(kāi)CSRF 驗(yàn)證的方式詳解
  • Django中ajax發(fā)送post請(qǐng)求 報(bào)403錯(cuò)誤CSRF驗(yàn)證失敗解決方案
  • Django結(jié)合ajax進(jìn)行頁(yè)面實(shí)時(shí)更新的例子
  • Django 通過(guò)JS實(shí)現(xiàn)ajax過(guò)程詳解
  • Django利用AJAX技術(shù)實(shí)現(xiàn)博文實(shí)時(shí)搜索

標(biāo)簽:欽州 三沙 景德鎮(zhèn) 喀什 濟(jì)南 臺(tái)灣 宿遷 黃山

巨人網(wǎng)絡(luò)通訊聲明:本文標(biāo)題《Django如何與Ajax交互》,本文關(guān)鍵詞  Django,如何,與,Ajax,交互,;如發(fā)現(xiàn)本文內(nèi)容存在版權(quán)問(wèn)題,煩請(qǐng)?zhí)峁┫嚓P(guān)信息告之我們,我們將及時(shí)溝通與處理。本站內(nèi)容系統(tǒng)采集于網(wǎng)絡(luò),涉及言論、版權(quán)與本站無(wú)關(guān)。
  • 相關(guān)文章
  • 下面列出與本文章《Django如何與Ajax交互》相關(guān)的同類(lèi)信息!
  • 本頁(yè)收集關(guān)于Django如何與Ajax交互的相關(guān)信息資訊供網(wǎng)民參考!
  • 推薦文章
    91手机在线视频| 看黄网站在线| 99精品国产热久久91蜜凸| 国产亚洲制服色| 亚洲精品在线一区二区| 亚洲欧美在线成人| 日韩亚洲欧美一区二区三区| 成人av黄色| 国产人妻黑人一区二区三区| 美国十次综合久久| 蜜臀一区二区三区精品免费视频| 亚洲国产精久久久久久久| 日韩久久精品| 伊人影院综合网| 久久影院免费观看| 久久综合九色综合久99| 成人黄页网站视频| 成人av片在线观看| 国产羞羞视频在线播放| 国产精品www网站| 天堂√在线观看一区二区| 亚洲三级毛片| 九色在线91| 亚洲天堂免费在线| 精品人妻在线视频| 女女同性女同一区二区三区按摩| 男女午夜刺激视频| 女人高潮被爽到呻吟在线观看| 日本免费一区二区三区等视频| 日本色图在线| 正义之心1992免费观看全集完整版| 国产成人在线视频免费播放| 亚洲高清二区| 香蕉久久夜色精品| 天天爽天天爽天天爽| 91porn在线视频| 日本一区二区高清不卡| 亚洲综合首页| 7777狠狠狠琪琪电影| 久久夜色精品国产欧美乱极品| 日韩伦理电影网站| 大伊人狠狠躁夜夜躁av一区| 精品国产91亚洲一区二区三区www| 国产9色视频| 亚洲美女在线播放| 日日躁夜夜躁aaaabbbb| 久久精品免费在线| jizz欧美性11| 日韩av中文字幕一区二区三区| 黄色香蕉视频在线观看| 色喇叭免费久久综合网| 午夜精品一区二区三| 午夜免费久久看| 在线一区二区三区| 国产一区二区三区国产| 日韩电影在线观看网站| 91久久国产视频| 欧美理论片在线观看| 欧美日韩高清影院| 亚洲欧美偷拍另类| 影音日韩av| 欧美一区二区大胆人体摄影专业网站| 亚洲福利国产精品| 国产成人亚洲综合青青| 日韩免费成人av| 亚洲精品视频一二三区| 懂色av蜜臀av粉嫩av永久| freemovies性欧美| 中文字幕 在线观看| 91久久久久久久久久久久| 国产视频精品久久久| 日韩中文欧美| 久久久久久久久久久亚洲| 97国产suv精品一区二区62| 男人和女人做事情在线视频网站免费观看| japanese中文字幕| 乱人伦精品视频在线观看| 免费看国产片在线观看| 在线观看三级视频欧美| 国产精品白丝jk黑袜喷水| 摸bbb搡bbb搡bbbb| 黑巨人与欧美精品一区| 日韩av在线免费观看| 国产一区二区三区成人欧美日韩在线观看| 国产福利免费在线观看| 色猫猫成人app| 欧美在线观看网站| 国产深喉视频一区二区| 国产精品视频不卡| 国内精品一区二区三区四区| 欧洲视频在线免费观看| 久久人妻免费视频| 亚洲第一成人网站| www.精品视频| 一本色道久久加勒比精品| 羞羞色午夜精品一区二区三区| 国产不卡在线观看| 精品亚洲aⅴ无码一区二区三区| 国产精彩视频在线| 日韩一区二区精品视频| 亚洲一区二区高清| 黄色网在线免费观看| 老师我好爽再深一点的视频| 中文字幕av在线一区二区三区| 一区二区三区免费看视频| 国产一级淫片久久久片a级| 久久亚洲一区二区三区四区| 成年人免费在线播放| 欧美激情视频一区二区三区在线播放| 日韩中文欧美在线| 亚洲视频国产| 少妇一级淫片免费放播放| 国产视频在线一区二区| 91精品精品| 亚洲一区二区不卡免费| 日韩亚洲欧美一区二区| 91亚洲精华国产精华精华液| 久久一区二区三区国产精品| 大胆av不用播放器在线播放| 美女视频网站黄色亚洲| 国产乱国产乱老熟300| 国产同性人妖ts口直男| 自拍偷自拍亚洲精品被多人伦好爽| 欧美极品影院| 欧美日韩国产欧| 欧美18免费视频| 岛国片在线免费观看| 免费成人黄色网| 日韩精品免费播放| 国产精品一区一区三区| 色网站免费在线观看| 久久一区二区三区超碰国产精品| 天堂av网手机版| 欧美日韩国产在线观看网站| 色婷婷精品大视频在线蜜桃视频| 99蜜月精品久久91| 久久av一区二区三区漫画| 蜜臀av粉嫩av懂色av| 另类欧美日韩国产在线| 亚洲一区二区视频在线播放| 一本色道a无线码一区v| 一区二区三区自拍| 91传媒免费视频| 色中色综合网| 91香蕉视频污| 国产成人一区二区三区小说| 亚洲视屏在线播放| 日本视频免费高清一本18| 国产人成视频在线观看| 国产精品区一区二| 波多野结衣视频播放| 中文.日本.精品| 国产精品久久久久久久久久精爆| 四虎精品一区二区三区| 成人黄色777网| www激情久久| 中文字幕日日夜夜| 91丨porny丨在线| 成人福利小视频| 久久综合伊人77777麻豆最新章节| 销魂美女一区二区三区视频在线| 99精品视频在线观看播放| 乱人伦中文字幕在线zone| 欧美日韩麻豆| 久久久免费观看视频| 91国产视频在线播放| 日本网址在线观看| 一级做a爰片久久毛片美女图片| 91精品久久久久| 色婷婷狠狠五月综合天色拍| 精品对白一区国产伦| 91青青草免费观看| 992tv成人免费影院| 成人动漫一区二区三区| 久久久久国产精品午夜一区| 国产精品久久麻豆| 外国精品视频在线观看| 日韩女优人人人人射在线视频| 国内精品伊人久久久久av影院| 91原色影院| 三级国产在线观看| 欧美成人aaaaⅴ片在线看| www日本在线观看| 成人黄色一级大片| 欧美激情伊人电影| 亚洲经典中文字幕| 日韩精品国内| 亚洲国产人成综合网站| 久久亚洲国产成人| 国产一区二区三区免费视频| 欧美在线观看不卡| 日韩激情久久| 欧美性猛交一区二区三区| 日韩免费毛片视频| 伊人久久大香线蕉av一区二区| 一区二区三区四区久久| 国产欧美 在线欧美| 国模私拍视频一区| 男人的天堂最新网址| 日韩在线观看a| 91久久国产综合久久91精品网站| 欧美激情奇米色| 蜜臀av一区二区在线免费观看| 好吊妞国产欧美日韩免费观看网站| 国产精彩视频在线观看免费蜜芽| 亚洲精品www久久久久久广东| 狠狠爱在线视频一区| 成人精品视频99在线观看免费| av网站观看| 成人精品一区二区三区电影黑人| 精品99久久| 国模私拍视频| 欧美日本乱大交xxxxx| 亚洲制服丝袜av| 亚洲精品视频在线观看免费| 日韩欧美在线字幕| 欧美日韩另类丝袜其他| 亚洲国产精品久久| 成人性生交大片免费看网站| 伊人久久综合一区二区| 日韩一区精品| 欧美电影免费看| 亚洲中文字幕在线观看| 亚洲第五色综合网| 成人免费观看在线网址| 国产在线精品免费av| 午夜一级久久| www.91av.cn| 综合激情视频| 亚洲日本免费| 亚洲精品乱码久久| 日韩有码视频在线| 人善交vide欧美| 国产剧情久久久久久| 欧美激情专区| 日韩a级作爱片一二三区免费观看| 天天操人人干| 亚洲综合爱爱久久网| 成年永久一区二区三区免费视频| 国产精品蜜臀av| 国产精品三级av在线播放| 国产91亚洲精品| 色先锋久久影院av| 要久久爱电视剧全集完整观看| 一个人免费观看视频www在线播放| 午夜成年人在线免费视频| 久久免费大视频| 日本中文字幕影院| 色综合天天狠天天透天天伊人| 亚洲国产精品视频一区| 天堂网在线最新版www中文网| 男人的天堂成人| 亚洲第一影院| 久久久久久久久国产精品| 久久免费视频播放| 亚洲毛片在线观看| av电影免费在线观看| av片在线观看网站| 国产精品久久久久久久久久久不卡| 欧美日韩国产一二| 国产一区二区三区在线观看精品| 日日干天夜夜| 精品人妻互换一区二区三区| 国产一级伦理片| 日韩一区欧美小说| 性生交大片免费全黄| 一区二区三区无码高清视频| 中文字幕亚洲一区二区va在线| 亚洲444eee在线观看| 丰满熟女人妻一区二区三| 国产色在线 com| 精品精品国产三级a∨在线| 九九热视频免费观看| 亚洲一区在线免费| 久久女同互慰一区二区三区| 国产一区二区精品在线| 中文字幕一区二区三三| 精品国产91九色蝌蚪| 高清孕妇孕交╳╳交| 天堂8中文在线最新版在线| 国产三级视频| 深爱激情综合| 一本色道久久综合熟妇| 免费看成人a| 久久久久.com| 性猛交xxxx乱大交孕妇印度| 日韩在线观看免费全集电视剧网站| 欧美国产乱视频| 成人深夜在线观看| 成人精品一区二区三区免费| 国产特黄一级片| 91综合久久一区二区| 小泽玛利亚av在线| 丰满岳妇乱一区二区三区| 日韩毛片高清在线播放| 波多野结衣一区二区三区免费视频| 国产日韩欧美二区| 999精品视频在线观看播放| 日韩aaaa| 黄色一级视频免费观看| 亚洲欧美日韩国产一区二区| www.亚洲一区二区三区| 国产日韩在线播放| 亚洲天堂中文在线| 麻豆电影在线| 国产日韩欧美91| 91极品视频在线观看| 丰满熟女一区二区三区| 久久色中文字幕| 人妻 丝袜美腿 中文字幕| 国产精品成人在线| 亚洲综合在线不卡| 国产一区二区不卡视频在线观看| 国产麻豆视频网站| 无码人妻丰满熟妇区毛片蜜桃精品| 日韩欧美一区二区三区| 日韩免费电影在线观看| 日韩和欧美一区二区| av在线免费网站| www.午夜激情| 国产在线视频不卡| 国产乱码精品一区二区三区不卡| 不卡视频观看| av日韩精品| 亚洲аv电影天堂网| 国产精品www.| 人人妻人人做人人爽| 久久久久亚洲av无码专区首jn|