zoukankan      html  css  js  c++  java
  • AJAX教程

    AJAX = Asynchronous JavaScript and XML(异步的 JavaScript 和 XML)。
    AJAX 不是新的编程语言,而是一种使用现有标准的新方法。
    AJAX 是与服务器交换数据并更新部分网页的艺术,在不重新加载整个页面的情况下。

    AJAX-创建XMLHttpRequest对象

    XMLHttpRequest 是 AJAX 的基础。

    • XMLHttpRequest 对象
      所有现代浏览器均支持 XMLHttpRequest 对象(IE5 和 IE6 使用 ActiveXObject)。
      XMLHttpRequest 用于在后台与服务器交换数据。这意味着可以在不重新加载整个网页的情况下,对网页的某部分进行更新。
    var xmlhttp;
    if (window.XMLHttpRequest)
    	{
    		// code for IE7+, Firefox, Chrome, Opera, Safari
    		xmlhttp=new XMLHttpRequest();
    	}
    else
    	{// code for IE6, IE5
    		xmlhttp=new ActiveXObject("Microsoft.XMLHTTP");
    	}
    

    AJAX - 向服务器发送请求

    XMLHttpRequest 对象用于和服务器交换数据。

    • 向服务器发送请求
      如需将请求发送到服务器,我们使用 XMLHttpRequest 对象的 open() 和 send() 方法:
    xmlhttp.open("GET","test1.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 更稳定也更可靠
    <html>
    <head>
    <script type="text/javascript">
    function loadXMLDoc()
    {
    var xmlhttp;
    if (window.XMLHttpRequest)
      {// code for IE7+, Firefox, Chrome, Opera, Safari
      xmlhttp=new XMLHttpRequest();
      }
    else
      {// code for IE6, IE5
      xmlhttp=new ActiveXObject("Microsoft.XMLHTTP");
      }
    xmlhttp.open("GET","/ajax/test1.txt",true);
    xmlhttp.send();
    document.getElementById("myDiv").innerHTML=xmlhttp.responseText;
    }
    </script>
    </head>
    <body>
    
    <div id="myDiv"><h2>Let AJAX change this text</h2></div>
    <button type="button" onclick="loadXMLDoc()">通过 AJAX 改变内容</button>
    
    </body>
    </html>
    

    AJAX - 服务器响应

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

    document.getElementById("myDiv").innerHTML=xmlhttp.responseText;
    
    xmlDoc=xmlhttp.responseXML;
    txt="";
    x=xmlDoc.getElementsByTagName("ARTIST");
    for (i=0;i<x.length;i++)
      {
      txt=txt + x[i].childNodes[0].nodeValue + "<br />";
      }
    document.getElementById("myDiv").innerHTML=txt;
    

    AJAX - onreadystatechange 事件

    • onreadystatechange 事件
      当请求被发送到服务器时,我们需要执行一些基于响应的任务。每当 readyState 改变时,就会触发 onreadystatechange 事件。readyState 属性存有 XMLHttpRequest 的状态信息。下面是 XMLHttpRequest 对象的三个重要的属性:

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

    • readyState
      存有 XMLHttpRequest 的状态。从 0 到 4 发生变化。
      0: 请求未初始化
      1: 服务器连接已建立
      2: 请求已接收
      3: 请求处理中
      4: 请求已完成,且响应已就绪

    • status
      200: "OK"
      404: 未找到页面

    xmlhttp.onreadystatechange=function()
      {
      if (xmlhttp.readyState==4 && xmlhttp.status==200)
        {
        document.getElementById("myDiv").innerHTML=xmlhttp.responseText;
        }
      }
    
  • 相关阅读:
    错因集锦
    组合数学12
    硬币购物
    考试套路整理
    考前模板整理
    我的友链
    P4127 [AHOI2009]同类分布
    P1836 数页码_NOI导刊2011提高(04)
    P4124 [CQOI2016]手机号码
    数位DP小结
  • 原文地址:https://www.cnblogs.com/qcssmd/p/5568130.html
Copyright © 2011-2022 走看看