zoukankan      html  css  js  c++  java
  • 【前端】Ajax

    一、Ajax简介

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

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

      AJAX特点:

    • 异步请求
    • 浏览器页面局部刷新(用户体验是在不知不觉中完成请求和响应过程)

      AJAX优缺点:

      优点:

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

      缺点:

    • AJAX并不适合所有场景,很多时候还是要使用同步交互;
    • AJAX虽然提高了用户体验,但无形中向服务器发送的请求次数增多了,导致服务器压力增大;
    • 因为AJAX是在浏览器中使用JavaScript技术完成的,所以还需要处理浏览器兼容性问题;

    二、jQuery实现的AJAX

    {% load staticfiles %}
    
    <!DOCTYPE html>
    
    <html lang="en">
    <head>
        <meta charset="UTF-8">
        <title>Title</title>
        <script src="{% static 'JS/jquery-3.1.1.js' %}"></script>
    </head>
    <body>
    
    <button class="send_Ajax">send_Ajax</button>
    
    <script>
          //$.ajax的两种使用方式:
    
          //$.ajax(settings);
          //$.ajax(url,[settings]);
    
    
           $(".send_Ajax").click(function(){
    
               $.ajax({
                   url:"/handle_Ajax/",
                   type:"POST",
                   data:{username:"Yuan",password:123},
    
                   success:function(data){
                       alert(data)
                   },
    
                     //=================== error============
    
                    error: function (jqXHR, textStatus, err) {
    
                            // jqXHR: jQuery增强的xhr
                            // textStatus: 请求完成状态
                            // err: 底层通过throw抛出的异常对象,值与错误类型有关
                            console.log(arguments);
                        },
    
                     //=================== complete============
    
                    complete: function (jqXHR, textStatus) {
                        // jqXHR: jQuery增强的xhr
                        // textStatus: 请求完成状态 success | error
                        console.log('statusCode: %d, statusText: %s', jqXHR.status, jqXHR.statusText);
                        console.log('textStatus: %s', textStatus);
                    },
    
                    //=================== statusCode============
              后端发送状态码代码
              obj=HttpResponse("OK")
              obj.status_code=304
              return obj
              
              前端代码 statusCode: {
    '403': function (jqXHR, textStatus, err) { console.log(arguments);
         //注意:后端模拟errror方式:HttpResponse.status_code=500 测试时使用 }, '400': function () { } } }) }) </script> </body> </html>

    success:过程执行正常时走的函数
    error:过程出现错误触发的函数
    complete:不管怎样都会触发的函数
    statusCode:根据状态码触发的函数

      2.1:$.ajax参数

    请求参数

    ######################------------data---------################
    
           data: 当前ajax请求要携带的数据,是一个json的object对象,ajax方法就会默认地把它编码成某种格式
                 (urlencoded:?a=1&b=2)发送给服务端;此外,ajax默认以get方式发送请求。
    
                 function testData() {
                   $.ajax("/test",{     //此时的data是一个json形式的对象
                      data:{
                        a:1,
                        b:2
                      }
                   });                   //?a=1&b=2
    ######################------------processData---------################
    
    processData:声明当前的data数据是否进行转码或预处理,默认为true,即预处理;if为false,
                 那么对data:{a:1,b:2}会调用json对象的toString()方法,即{a:1,b:2}.toString()
                 ,最后得到一个[object,Object]形式的结果。
                
    ######################------------contentType---------################
    
    contentType:默认值: "application/x-www-form-urlencoded"。发送信息至服务器时内容编码类型。
                 用来指明当前请求的数据编码格式;urlencoded:?a=1&b=2;如果想以其他方式提交数据,
                 比如contentType:"application/json",即向服务器发送一个json字符串:
                   $.ajax("/ajax_get",{
                 
                      data:JSON.stringify({
                           a:22,
                           b:33
                       }),
                       contentType:"application/json",
                       type:"POST",
                 
                   });                          //{a: 22, b: 33}
    
                 注意:contentType:"application/json"一旦设定,data必须是json字符串,不能是json对象
    
    
    ######################------------traditional---------################
    
    traditional:一般是我们的data数据有数组时会用到 :data:{a:22,b:33,c:["x","y"]},
                  traditional为false会对数据进行深层次迭代;

    响应参数

    /*
    
    dataType:  预期服务器返回的数据类型,服务器端返回的数据会根据这个值解析后,传递给回调函数。
                默认不需要显性指定这个属性,ajax会根据服务器返回的content Type来进行转换;
                比如我们的服务器响应的content Type为json格式,这时ajax方法就会对响应的内容
                进行一个json格式的转换,if转换成功,我们在success的回调函数里就会得到一个json格式
                的对象;转换失败就会触发error这个回调函数。如果我们明确地指定目标类型,就可以使用
                data Type。
                dataType的可用值:html|xml|json|text|script
                见下dataType实例
    
    */
  • 相关阅读:
    一个简单的投票功能
    快速删除.svn文件夹
    屏蔽关键字
    批量过滤POST GET数据
    JS识别ios & 安卓
    HashMap
    GC
    类与类之间的关系
    玩转大数据之Apache Pig如何与Apache Lucene集成
    大话设计模式-简单工厂模式
  • 原文地址:https://www.cnblogs.com/78pikaqiu/p/7455030.html
Copyright © 2011-2022 走看看