python_fullstack—Django框架(九)-AJAX初识

Ajax初识

一、Ajax简介

1、概述

  • AJAX(Asynchronous Javascript And XML)即“异步Javascript和XML”。意思是使用Javascript语言与服务器进行异步交互,传输的数据为XML(当然,传输的数据不只是XML)。

  • 在此我们还要知道一个概念,同步交互与异步交互

    • 同步交互:客户端发出一个请求后,需要等待服务器响应结束后,才能发出后续请求
    • 异步交互:客户端发出一个请求后,无需等待服务器响应结束,就可以发出第二后续请求
  • Ajax特点:

    • 异步交互
    • 浏览器局部刷新页面

2、Ajax常见应用情景

  1. 搜索引擎根据用户输入的关键字,自动提示检索关键字
  2. 站点注册时用户信息查重

3、Ajax优缺点

  • 优点

    • AJAX使用JavaScript技术向服务器发送异步请求
    • AJAX请求无须刷新整个页面
    • 因为服务器响应内容不再是整个页面,而是页面中的部分内容,所以AJAX性能高
  • 缺点

    • 也正是因为Ajax的局部刷新,如果滥用Ajax的话对服务器会造成更大的压力

二、jQuery实现Ajax

1、form数据的序列化

$('#submit').click(function(){
    $('#form').serialize();        //会根据input里面的name,把数据序列化成字符串;eg:name=yang
    $('#form').serializeArray();    //会根据input里面的name,把数据序列化成数组;eg:[object]
  //注意:没有name会获取不到值


    //下面两种不是jQuery的方法
    JSON.parse()    //json字符串转化为json对象
    JSON.stringify()    //json对象转化为json字符串
});

2、标准格式

$.ajax({
    url:'/ajax_practice/',
    type:'POST', //GET
    async:true,  //或false,是否异步
    data:{
           name:'yang',
           age:18,
         },
    timeout:5000,       //超时时间
    dataType:'json',    //返回的数据格式:json/xml/html/script/jsonp/text
    beforeSend:function(xhr){
        console.log(xhr)
        console.log('发送前')
    },
    success:function(data,textStatus,jqXHR){
        console.log(data)
        console.log(textStatus)
        console.log(jqXHR)
    },
    error:function(xhr,textStatus){
        console.log('错误')
        console.log(xhr)
        console.log(textStatus)
    },
    complete:function(){
        console.log('结束')
    }
})

3、简单实现

  • Django项目用Ajax实现页面加法计算器
# -----------------------urls.py中-----------------------
from django.conf.urls import url
from app01 import views

urlpatterns=[
    url(r'add/',views.add),
    url(r'ajax_add/',views.ajax_add),
]

# -----------------------views.py中-----------------------
from django.shortcuts import render, HttpResponse

def add(request):
    i1 = int(request.Get.get('i1', 0))
    i2 = int(request.Get.get('i2', 0))
    res = i1 + i2
    return render(request,'add.html',{'i1':i1,'i2':i2})

def ajax_add(request):
    i1 = int(request.Get.get('i1', 0))
    i2 = int(request.Get.get('i2', 0))
    res = i1 + i2
    return HttpResponse(res)

# -----------------------add.html中-----------------------

"en">

    "utf-8">
    "X-UA-Compatible" content="IE=edge">
    "viewport" content="width=device-width, initial-scale=1">
    
    "https://cdn.bootcss.com/bootstrap/3.3.7/css/bootstrap.min.css" rel="stylesheet">
    Ajax练习



"/add/" method="get"> "text" id="i1" name="i1" value="{{ i1 }}"> + "text" id="i2" name="i2" value="{{ i2 }}"> = "text" id="res" name="ret" value="{{ res }}"> "b1" type="button" value="发送AJAX请求"> "submit" value="submit提交">

4、Ajax请求设置csrf_token

  • 方法一
// 通过获取隐藏的input标签中的csrfmiddlewaretoken值,放置在data中发送。
$.ajax({
  url: "/cookie_ajax/",
  type: "POST",
  data: { "username": "Q1mi", "password": 123456, "csrfmiddlewaretoken": $("[name = 'csrfmiddlewaretoken']").val()  // 使用JQuery取出csrfmiddlewaretoken的值,拼接到data中
 },
  success: function (data) {
    console.log(data);
  }
})
  • 方法二
//通过获取返回的cookie中的字符串 放置在请求头中发送。
//注意:需要引入一个jquery.cookie.js插件
$.ajax({
  url: "/cookie_ajax/",
  type: "POST",
  headers: {"X-CSRFToken": $.cookie('csrftoken')},  // 从Cookie取csrf_token,并设置ajax请求头
  data: {"username": "Q1mi", "password": 123456},
  success: function (data) {
    console.log(data);
  }
})

// 或者用自己写一个getCookie方法
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');

// 每一次都这么写太麻烦了,可以使用$.ajaxSetup()方法为ajax请求统一设置
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);
    }
  }
});

三、原生JavaScript实现Ajax

$('#send').click(function(){
    //请求的5个阶段,对应readyState的值
        //0: 未初始化,send方法未调用;
        //1: 正在发送请求,send方法已调用;
        //2: 请求发送完毕,send方法执行完毕;
        //3: 正在解析响应内容;
        //4: 响应内容解析完毕;

    var data = 'name=yang';
    var xhr = new XMLHttpRequest();        //创建一个ajax对象
    xhr.onreadystatechange = function(event){    //对ajax对象进行监听
        if(xhr.readyState == 4){    //4表示解析完毕
            if(xhr.status == 200){    //200为正常返回
                console.log(xhr)
            }
        }
    };
    xhr.open('POST','url',true);    //建立连接,参数一:发送方式,二:请求地址,三:是否异步,true为异步
    xhr.setRequestHeader('Content-type','application/x-www-form-urlencoded');    //可有可无
    xhr.send(data);        //发送
});

四、补充内容

1、Django内置的serializers

# 在Django项目的views中,我们可能会遇到需将包含多个对象的列表返回至HTML页面,然而返回页面的数据必须是序列化的字符串,所以我们就要用到Django内置的serializers进行序列化

def books_json(request):
    book_list = models.Book.objects.all()[0:10]
    from django.core import serializers
    ret = serializers.serialize("json", book_list)
    return HttpResponse(ret)
# 我们的数据中经常有日期时间,也就是datetime对象,而json.dumps是无法处理这样在类型的,那就需要通过自定义处理器来做扩展,如下:

class JsonCustomEncoder(json.JSONEncoder):
    """
    自定义一个支持序列化时间格式的类
    """
    def default(self, o):
        if isinstance(o, datetime):
            return o.strftime("%Y-%m-%d %H:%M:%S")
        elif isinstance(o, date):
            return o.strftime("%Y-%m-%d")
        else:
            return json.JSONEncoder.default(self, o)

def books_json(request):
    book_list = models.Book.objects.all().values_list("title", "publish_date")
    ret = json.dumps(list(book_list), cls=JsonCustomEncoder)
    return HttpResponse(ret)

2、SweetAlert插件推荐

  • 插件链接地址:https://github.com/lipis/bootstrap-sweetalert

  • 简单示例

$(".btn-danger").on("click", function () {
  swal({
    title: "你确定要删除吗?",
    text: "删除可就找不回来了哦!",
    type: "warning",
    showCancelButton: true,
    confirmButtonClass: "btn-danger",
    confirmButtonText: "删除",
    cancelButtonText: "取消",
    closeOnConfirm: false }, function () { var deleteId = $(this).parent().parent().attr("data_id");
      $.ajax({
        url: "/delete_book/",
        type: "post",
        data: {"id": deleteId},
        success: function (data) { if (data.status === 1) {
            swal("删除成功!", "你可以准备跑路了!", "success");
          } else {
            swal("删除失败", "你可以再尝试一下!", "error")
          }
        }
      })
    });
})
  • 效果图

五、官方链接

https://api.jquery.com/category/ajax/

你可能感兴趣的:(Django框架)