AJAX


一  概述

AJAXAsynchronous Javascript And XML),使用Javascript語言與服務器進行異步交互,傳輸的數據為XML(當然,傳輸的數據不只是XML,目前以json為主)。

應用場景:

注冊時候的用戶名的查重;

搜索引擎根據輸入的關鍵字,自動提示檢索關鍵字:當文件框發生了輸入變化,使用AJAX向服務器發送一個請求,然后服務器會把查詢到的結果響應給瀏覽器,最后再把后端返回的結果展示出來,

  • 整個過程中頁面沒有刷新,只是刷新頁面中的局部位置而已!
  • 當請求發出后,瀏覽器還可以進行其他操作,無需等待服務器的響應!

二   json基礎

合格的json對象:

["one", "two", "three"]
{ "one": 1, "two": 2, "three": 3 }
{"names": ["張三", "李四"] }
[ { "name": "張三"}, {"name": "李四"} ] 

 不合格的json對象:

{ name: "張三", 'age': 32 }  // 屬性名必須使用雙引號
[32, 64, 128, 0xFFF] // 不能使用十六進制值
{ "name": "張三", "age": undefined }  // 不能使用undefined
{ "name": "張三",
  "birthday": new Date('Fri, 26 Aug 2011 07:13:10 GMT'),
  "getName":  function() {return this.name;}  // 不能使用函數和日期對象
}

1.  stringify與parse方法

JSON.parse(): 用於將一個 JSON 字符串轉換為 JavaScript 對象 

JSON.parse('{"name":"Q1mi"}');
JSON.parse('{name:"Q1mi"}') ;   // 錯誤
JSON.parse('[18,undefined]') ;   // 錯誤

JSON.stringify(): 用於將 JavaScript 值轉換為 JSON 字符串。 

JSON.stringify({"name":"Q1mi"})

三  jQuery實現的AJAX

        //ajax驗證是否重名
        $("#author_input1").blur(function () {
            var _this = $(this);
            $.ajax({
                url: "/mainapp/author_name/",
                type: "POST",
                data: {name: _this.val(),
             }, success: function (data) { _this.next().text(data); _this.parent().addClass('has-error'); } }) })

1.  json格式轉換

$("#b1").on("click", function () {
    $.ajax({
      url:"/ajax_add/",
      type:"GET",
      data:{"i1":$("#i1").val(),"i2":$("#i2").val(),"hehe": JSON.stringify([1, 2, 3])},
      success:function (data) {
        $("#i3").val(data);
      }
    })
  })

views向http傳遞參數

import json
from django.http import JsonResponse

四 AJAX請求設置csrf_token

1. 方式一

通過獲取隱藏的input標簽中的csrfmiddlewaretoken值

$.ajax({
  url: "/cookie_ajax/",
  type: "POST",
data: {
"username": "Q1mi", "password": 123456, "csrfmiddlewaretoken": $("[name = 'csrfmiddlewaretoken']").val() // 使用jQuery取出csrfmiddlewaretoken的值,拼接到data中
},
  success: function (data) {
    console.log(data);
  }
})

或者:

$.ajax({
  url: "/cookie_ajax/",
  type: "POST",
  headers: {"X-CSRFToken":$("[name = 'csrfmiddlewaretoken']").val(),  // 從Cookie取csrftoken,並設置到請求頭中
  data: {"username": "Q1mi", "password": 123456},
  success: function (data) {
    console.log(data);
  }
} 

2. 全局設置

在static新建一文件,在母版中導入script

function getCookie(name) {
    var cookieValue = null;
    if (document.cookie && document.cookie !== '') {
        var cookies = document.cookie.split(';');
        for (var i = 0; i < cookies.length; i++) {
            var cookie = jQuery.trim(cookies[i]);
            // Does this cookie string begin with the name we want?
            if (cookie.substring(0, name.length + 1) === (name + '=')) {
                cookieValue = decodeURIComponent(cookie.substring(name.length + 1));
                break;
            }
        }
    }
    return cookieValue;
}

var csrftoken = getCookie('csrftoken');

function csrfSafeMethod(method) {
    // these HTTP methods do not require CSRF protection
    return (/^(GET|HEAD|OPTIONS|TRACE)$/.test(method));
}

$.ajaxSetup({
    beforeSend: function (xhr, settings) {
        if (!csrfSafeMethod(settings.type) && !this.crossDomain) {
            xhr.setRequestHeader("X-CSRFToken", csrftoken);
        }
    }
});

注意:

從cookie中取csrftoken時,需要確保cookie存在csrftoken值。如果HTML文件中沒有包含 {% csrf_token %},Django可能不會設置CSRFtoken的cookie。

這個時候需要使用ensure_csrf_cookie()裝飾器強制設置Cookie。

django.views.decorators.csrf import ensure_csrf_cookie

@ensure_csrf_cookie
def login(request):
    pass

五  ajax跳轉

        //刪除數據提示框
        $('button[name="delete_button"]').click(function () {
           var _this = $(this); //隨時監測$(this)的具體值
            swal({
                    title: "確認刪除?",
                    text: "刪除后數據不可恢復!",
                    type: "warning",
                    showCancelButton: true,
                    confirmButtonClass: "btn-danger",
                    confirmButtonText: "Yes, delete it!",
                    closeOnConfirm: false
                },
                function () {
                    console.log(_this);
                    $.ajax({
                        url: "/mainapp/author_delete/",
                        type: "POST",
                        data: {id: _this.parent().next().text()},
                        success: function (data) { 
                            window.location.href = "/mainapp/author/"    //頁面跳轉
                        }
                    });
                });
        });

 


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM