zoukankan      html  css  js  c++  java
  • AJAX简述

    1.概述

    异步的js和xml

    可以通过AJAX实现异步访问服务器,并局部刷新网页

    2.同步交互与异步交互

    • 同步(串行)
      向服务器发送一个请求,必须等待响应结束,才能发起第二个请求,
      在服务器处理期间,浏览器不能干别的事。
      通常会刷新整个页面。
    • 异步(交替)
      向服务器发送一个请求,无须等待响应结束,就能发起第二个请求,
      在服务器处理期间,浏览器可以干别的事。
      通常会刷新局部页面

    3.应用场景

    百度搜索框
    用户名检验
    。。。

    4.优缺点

    • 优点:
      异步交互,提高了用户的体验。
      服务器只响应了部分数据,而不是整个页面,所以降低了服务器的压力。
    • 缺点:
      AJAX不适用所有场景,比如页面跳转。
      AJAX会增加服务器压力,因为可能会无端增加访问服务器的次数

    5.JavaScript实现AJAX

    第一步--获取XMLHttpRequest对象

    var xmlHttp = ajaxFunction();
    function ajaxFunction(){
        var xmlHttp;
        try{
    //现代浏览器(IE7+、Firefox、Chrome、Safari 和 Opera)都有内建的 XMLHttpRequest 对象
            xmlHttp = new XMLHttpRequest();
        }catch(e){
            try{
                //IE6.0
                xmlHttp = new ActiveXObject("Msxml2.XMLHTTP");
            }catch(e){
                try{
                    //IE5.0及更早版本
                    xmlHttp = new ActiveXObject("Microsoft.XMLHTTP");
                }catch(e){
                    alert("...");
                    throw e;
                }
            }
        }
        return xmlHttp;
    }
    

    第二步--打开与服务器的连接

    xmlHttp.open(method, url, async);
    
    • method: 请求方式, 可以是GET或POST
    • url: 所要访问的服务器中资源的路径如:/servlet/AServlet
    • async: 是否为异步传输, true 表示为异步。传输一般都是true。

    第三步--发送请求

    xmlHttp.setRequestHeader("Content-Type","application/x-www-form-urlencoded");//通知服务器发送的数据是请求参数 
    xmlHttp.send("xxxx"); //注意, 如果不给参数可能会造成部分浏览器无法发送请求
    xmlHttp.send("username="+username+"&psw="+)
    
    参数:

    如果是GET请求, 可以是null, 因为GET提交参数会拼接在url后面。
    如果是POST请求, 传入的就是请求参数,如:"username=张飞&psw=123"

    第四步--注册监听

    在XMLHttpRequest对象的一个事件上注册监听器:onreadystatechange
    一共有五个状态:(xmlHttp.readyState)

    • 0状态:表示刚创建XMLHttpRequest对象, 还未调用open()方法。
    • 1状态:表示刚调用open()方法, 但是还没有调用send()方法发送请求。
    • 2状态:调用完了send()方法了, 请求已经开始。
    • 3状态:服务器已经开始响应, 但是不代表响应结束。
    • 4状态:服务器响应结束!(通常我们只关心这个状态)

    获取xmlHttp对象的状态:
    var state = xmlHttp.readyState;//可能得到0, 1, 2, 3, 4

    获取服务器响应的状态码:
    var status = xmlHttp.status;

    获取服务器响应的内容

    var data = xmlHttp.responseText;//得到服务器响应的文本格式的数据
    // readyState0 --> 1
    
    /* 注册监听, 时刻监听服务器处理请求的状态 */
    xmlHttp.onreadystatechange = function(){
        if(xmlHttp.readyState == 4){
            //状态为4表示服务器已经处理完成, 但是不代表处理成功
            if(xmlHttp.status == 200){//当状态码为200, 表示服务器成功的处理了请求
                var result = xmlHttp.responseText();
                //xxx
            }
        }
    }
    

    6.jQuery实现AJAX

    $ .get() 或 $ .post()
    $.get(url,[data],[callback])
    
    • url:发送请求的url地址
    • data:可选,向服务器发送的数据,需要json格式
    • callback:可选,回调函数,即请求成功后执行的函数
    load()
    $(selector).load(url,[data],[callback])
    
    • $(selector):选择器,可以选中某个元素,并将服务器的返回值填充到这个元素中
    • url:发送请求的url地址
    • data:可选,向服务器发送的数据,需要json格式
    • callback:可选,回调函数,即请求成功后执行的函数
    ajax()
    $.ajax(url,[data],[async],[type],[success])
    
    • url:发送请求的url地址
    • data:可选,向服务器发送的数据,需要json格式
    • async:可选,默认是true,表示异步,false为同步
    • type:可选,请求方式
    • success:可选,回调函数,即请求成功后执行的函数
  • 相关阅读:
    RocketMQ源码 — 十、 RocketMQ顺序消息
    RocketMQ源码 — 九、 RocketMQ延时消息
    RocketMQ源码 — 八、 RocketMQ消息重试
    HDU3439 Sequence
    Cipolla算法学习小记
    BZOJ2286: [Sdoi2011]消耗战
    BZOJ4873 寿司餐厅
    BZOJ1718 [Usaco2006 Jan] Redundant Paths 分离的路径
    BZOJ1123 [POI2008]BLO
    BZOJ3996 TJOI2015线性代数
  • 原文地址:https://www.cnblogs.com/juzhuxiaozhu/p/12750821.html
Copyright © 2011-2022 走看看