ajax学习摘抄笔记

AJAX = Asynchronous JavaScript and XML(异步的 JavaScript 和 XML)。html

    AJAX 不是新的编程语言,而是一种使用现有标准的新方法。ajax

    AJAX 最大的优势是在不从新加载整个页面的状况下,能够与服务器交换数据并更新部分网页内容。数据库

    AJAX 不须要任何浏览器插件,但须要用户容许JavaScript在浏览器上执行。编程

AJAX 应用

  • 运用XHTML+CSS来表达资讯;浏览器

  • 运用JavaScript操做DOM(Document Object Model)来执行动态效果;缓存

  • 运用XML和XSLT操做资料;服务器

  • 运用XMLHttpRequest或新的Fetch API与网页服务器进行异步资料交换;异步

  • 注意:AJAX与Flash、Silverlight和Java Applet等RIA技术是有区分的。async

    AJAX是基于现有的Internet标准

    AJAX是基于现有的Internet标准,而且联合使用它们:编程语言

  • XMLHttpRequest 对象 (异步的与服务器交换数据)
  • JavaScript/DOM (信息显示/交互)
  • AJAX应用程序与浏览器和平台无关的!

  • CSS (给数据定义样式)
  • XML (做为转换数据的格式)

    AJAX - 建立 XMLHttpRequest 对象

    XMLHttpRequest 是 AJAX 的基础。

    XMLHttpRequest 对象

    全部现代浏览器均支持 XMLHttpRequest 对象(IE5 和 IE6 使用 ActiveXObject)。

    XMLHttpRequest 用于在后台与服务器交换数据。这意味着能够在不从新加载整个网页的状况下,对网页的某部分进行更新。

    建立 XMLHttpRequest 对象

    全部现代浏览器(IE7+、Firefox、Chrome、Safari 以及 Opera)均内建 XMLHttpRequest 对象。

    建立 XMLHttpRequest 对象的语法:

    variable=new XMLHttpRequest();

    老版本的 Internet Explorer (IE5 和 IE6)使用 ActiveX 对象:

    variable=new ActiveXObject("Microsoft.XMLHTTP");

    为了应对全部的现代浏览器,包括 IE5 和 IE6,请检查浏览器是否支持 XMLHttpRequest 对象。若是支持,则建立 XMLHttpRequest 对象。若是不支持,则建立 ActiveXObject :
     

    向服务器发送请求

    如需将请求发送到服务器,咱们使用 XMLHttpRequest 对象的 open() 和 send() 方法:

    xmlhttp.open("GET","ajax_info.txt",true);
    xmlhttp.send();

    方法 描述
    open(method,url,async)

    规定请求的类型、URL 以及是否异步处理请求。

    • method:请求的类型;GET 或 POST
    • url:文件在服务器上的位置
    • async:true(异步)或 false(同步)
    send(string)

    将请求发送到服务器。

    • string:仅用于 POST 请求


    GET 仍是 POST?

    与 POST 相比,GET 更简单也更快,而且在大部分状况下都能用。

    然而,在如下状况中,请使用 POST 请求:

  • 没法使用缓存文件(更新服务器上的文件或数据库)
  • 向服务器发送大量数据(POST 没有数据量限制)
  • 发送包含未知字符的用户输入时,POST 比 GET 更稳定也更可靠

    Async=true

    当使用 async=true 时,请规定在响应处于 onreadystatechange 事件中的就绪状态时执行的函数:

    实例

    xmlhttp.onreadystatechange=function(){
    if(xmlhttp.readyState==4&&xmlhttp.status==200){ document.getElementById("myDiv").innerHTML=xmlhttp.responseText;
    }
    }
    xmlhttp.open("GET","/try/ajax/ajax_info.txt",true); xmlhttp.send();

    Async = false

    如需使用 async=false,请将 open() 方法中的第三个参数改成 false:

    xmlhttp.open("GET","test1.txt",false);

    咱们不推荐使用 async=false,可是对于一些小型的请求,也是能够的。

    请记住,JavaScript 会等到服务器响应就绪才继续执行。若是服务器繁忙或缓慢,应用程序会挂起或中止。

    注意:当您使用 async=false 时,请不要编写 onreadystatechange 函数 - 把代码放到 send() 语句后面便可:

    实例

    xmlhttp.open("GET","/try/ajax/ajax_info.txt",false);
    xmlhttp.send();
    document.getElementById("myDiv").innerHTML=xmlhttp.responseText;

    服务器响应

    如需得到来自服务器的响应,请使用 XMLHttpRequest 对象的 responseText 或 responseXML 属性。

    属性 描述
    responseText 得到字符串形式的响应数据。
    responseXML 得到 XML 形式的响应数据。
     

    onreadystatechange 事件

    当请求被发送到服务器时,咱们须要执行一些基于响应的任务。

    每当 readyState 改变时,就会触发 onreadystatechange 事件。

    readyState 属性存有 XMLHttpRequest 的状态信息。

    下面是 XMLHttpRequest 对象的三个重要的属性:

    属性 描述
    onreadystatechange 存储函数(或函数名),每当 readyState 属性改变时,就会调用该函数。
    readyState

    存有 XMLHttpRequest 的状态。从 0 到 4 发生变化。

    • 0: 请求未初始化
    • 1: 服务器链接已创建
    • 2: 请求已接收
    • 3: 请求处理中
    • 4: 请求已完成,且响应已就绪
    status 200: "OK"
    404: 未找到页面

    在 onreadystatechange 事件中,咱们规定当服务器响应已作好被处理的准备时所执行的任务。

    当 readyState 等于 4 且状态为 200 时,表示响应已就绪:
     

    100——客户必须继续发出请求

    101——客户要求服务器根据请求转换HTTP协议版本

    200——交易成功

    201——提示知道新文件的URL

    202——接受和处理、但处理未完成

    203——返回信息不肯定或不完整

    204——请求收到,但返回信息为空

    205——服务器完成了请求,用户代理必须复位当前已经浏览过的文件

    206——服务器已经完成了部分用户的GET请求

    300——请求的资源可在多处获得

    301——删除请求数据

    302——在其余地址发现了请求数据

    303——建议客户访问其余URL或访问方式

    304——客户端已经执行了GET,但文件未变化

    305——请求的资源必须从服务器指定的地址获得

    306——前一版本HTTP中使用的代码,现行版本中再也不使用

    307——申明请求的资源临时性删除

    400——错误请求,如语法错误

    401——请求受权失败

    402——保留有效ChargeTo头响应

    403——请求不容许

    404——没有发现文件、查询或URl

    405——用户在Request-Line字段定义的方法不容许

    406——根据用户发送的Accept拖,请求资源不可访问

    407——相似401,用户必须首先在代理服务器上获得受权

    408——客户端没有在用户指定的时间内完成请求

    409——对当前资源状态,请求不能完成

    410——服务器上再也不有此资源且无进一步的参考地址

    411——服务器拒绝用户定义的Content-Length属性请求

    412——一个或多个请求头字段在当前请求中错误

    413——请求的资源大于服务器容许的大小

    414——请求的资源URL长于服务器容许的长度

    415——请求资源不支持请求项目格式

    416——请求中包含Range请求头字段,在当前请求资源范围内没有range指示值,请求也不包含If-Range请求头字段

    417——服务器不知足请求Expect头字段指定的指望值,若是是代理服务器,多是下一级服务器不能知足请求

    500——服务器产生内部错误

    501——服务器不支持请求的函数

    502——服务器暂时不可用,有时是为了防止发生系统过载

    503——服务器过载或暂停维修

    504——关口过载,服务器使用另外一个关口或服务来响应用户,等待时间设定值较长

    505——服务器不支持或拒绝支请求头中指定的HTTP版本

    ajax实例:http://www.runoob.com/ajax/ajax-examples.html
相关文章
相关标签/搜索