zoukankan      html  css  js  c++  java
  • Ajax学习

    1.概念

    Ajax是Asynchronous JavaScript and XML的缩写,就是异步JavaScript与XML。

    传统WEB应用中,页面中用户的每一次操作都将触发一次返回Web服务器的HTTP请求,服务器进行相应处理后返回相应的HEML页面。而在Ajax应用中,页面中用户的操作将通过Ajax

    引擎与服务器端进行通信,然后将返回结果提交给客户端Ajax引擎,再由Ajax引擎来决定将这些数据插入到页面的指定位置。

    所以Ajax最大的特点就是无刷新的更新页面,减轻了服务器的负担。

     2.Ajax技术

    Ajax是JavaScript、XML、CSS、DOM等多种已有技术的组合。

    2.1XMLHttpRequest

    Ajax最核心的技术就是XMLHttpRequest,它是一个具有应用程序接口的JavaScript对象,通过它,可以只同服务器进行数据层面的交换,而不用每次都刷新页面。

     XMLHttpRequest对象的常用方法及常用属性如下:

     

    2.2JavaScript

    在Web页面中添加动态脚本代码的解释性程序语言。

    2.3DOM

    Document Object Model(文档对象模型),是表示文档和访问、操作构成文档的各种元素(如HTML标记和文本串)的应用程序接口。在Ajax应用中,通过JavaScript操作DOM,可以达到在不刷新页面的情况下实时修改用户界面的目的。

    2.4XML

    Extensible Markup Language(可扩展的标记语言),提供了用于描述结构化数据的格式。

    2.5CSS

    层叠样式表,用于页面布局,通过改变文档对象的CSS属性控制页面的外观和行为。

    3.传统Ajax的工作流程

     3.1发送请求

    1)初始化XMLHttpRequest对象

    使用XMLHttpRequest之前需要进行初始化,初始化的方法如下:

    if(window.XMLHttpRequest){
        http_request=new XMLHttpRequest(); //非IE浏览器
    }
    else if(window.ActiveObject){    //IE浏览器
        try{
            http_request=new ActiveObject("Msxml2.XMLHTTP");
        }
        catch(e){
            try{
                http_request=new ActiveObject("Microsoft.XMLHTTP");
            }
            catch(e){}
        }
    }

    2)为XMLHttpRequest对象指定一个回调函数,用于对返回结果进行处理。

    http_request.onreadystatechange=getResult; //调用回调函数

    如果要指定传递的参数,可以应用以下方法:

    http_request.onreadystatechange=function(){getResult(param)};

    3)创建一个与服务器的连接,在创建时,需要指定发送请求的方式,以及设置是否采用异步方式发送请求

    http_request.open("GET", url, true);
    // http_request.open("POST", url,true);

    4)向服务器发送请求。利用send()方法可以实现向服务器发送请求,该方法需要传递一个参数,如果发送的是GET请求,可以将参数设置为null;如果发送的是POST请求,该方法需要通过该参数指定要发送的请求参数。

    发送GET请求:

    http_request.send(null);

    发送POST请求:

    http_request.setRequestHeader("Content-Type", "application/x-www-form-urlencoded");
    var param="user="+......;//组合参数
    http_request.send(param);

    3.2处理服务器响应

    在指定的回调函数中,首先需要判断服务器的请求状态,保证请求已完成,然后再根据服务器的HTTP状态码,判断服务器对请求的响应是否成功,如果成功,则获取服务器的响应反馈给客户端。XMLHttpRequest对象提供了两个用来访问服务器响应的属性:一个是responseText属性,返回字符串响应;另一个是responseXML属性,返回XML响应。

    1)处理字符串响应

    function getResult(){
        if(http_request.readyState==4){           //判断请求状态
            if(http_request.status==200){         //请求成功,开始处理相应
                alert(http_request.responseText);  //弹出提示对话框显示响应结果
            }else{
                alert("错误");
            }
            
        }
    }

    2)处理XML响应

    var xmldoc=http_request.responseXML;

    解析xmldoc

  • 相关阅读:
    记一次排查tomcat耗费CPU过高的经历
    记录一次PHP项目报502的问题
    工作职责与工作协调
    如何提升团队效率
    接手老项目的方法总结
    如何快速确定需求的技术实现方案
    PHP中的赋值-引用or传值?
    性能优化-开发流程中的性能优化
    一周阅读列表(20131111-20131117)
    一周阅读列表(20131104-20131110)
  • 原文地址:https://www.cnblogs.com/galway/p/4648706.html
Copyright © 2011-2022 走看看