• AJAX之学习笔记(持续更新......)


      以前的学习都是在Evernote上做的笔记,之前也在博客园注册过,但是一直没用,就荒废了。最近想既然是学技术的,用这个来记我的一些日常学习笔记是在好不过了。

      总之加油吧~~~希望自己能早日摆脱新手这个称呼嘻嘻(*^__^*) 

      1、AJAX的定义

    AJAX=Asynchronous JavaScript and XML(异步的JavaScript和XML)——此处应先了解HTML、XHTML、CSS、JavaScript和DOM结构。

    AJAX是一种新方法,不是新的编程语言,可以在不需要重新加载网页的情况下,与服务器交换数据以更新网页。

    通过在后台与服务器进行少量数据交换,AJAX 可以使网页实现异步更新。

      2、AJAX的工作原理

    (1)、创建XMLHttpRequest对象

    XMLHttpRequest用于在后台和服务器交换数据。所有浏览器都支持(IE5、IE6使用ActiveXObject)

      创建XMLHttpRequest对象:(所有现代浏览器(IE7+、Firefox、Chrome、Safari 以及 Opera)均内建 XMLHttpRequest 对象)

      语法:variable=new XMLHttpRequest();

      老版本的IE5、IE6使用ActiveX对象:variable=new ActiveXObject("Mcrosoft.XMLHttp");

    为了应对所有的现代浏览器,包括 IE5 和 IE6,请检查浏览器是否支持 XMLHttpRequest 对象。如果支持,则创建 XMLHttpRequest 对象。如果不支持,则创建 ActiveXObject :

    var xmlhttp;

    if(window.XMLHttpRequest)

    {

    // code for IE7+, Firefox, Chrome, Opera, Safari
    xmlhttp=new XMLHttpRequest();

    }else{

    // code for IE6, IE5
    xmlhttp=new ActiveXObject("Mcrosoft.XMLHttp");

    }

      (2)、向服务器发送请求

    使用open()和send()方法:xmlhttp.open("GET","test.txt",true);xmlhttp.send();

    下面来介绍open()和send()方法:

    open(method,url,async):规定请求的类型、URL 以及是否异步处理请求。method(请求类型;GET或POST),url(文件在服务器的位置),async(true——异步或false——同步);open() 方法的 url 参数是服务器上文件的地址。该文件可以是任何类型的文件,比如 .txt 和 .xml,或者服务器脚本文件,比如 .asp 和 .php (在传回响应之前,能够在服务器上执行任务)。

    send(string):将请求发送到服务器,string(仅用于post请求)

    这里我简单的介绍一下GET和POST:

    一个简单的GET请求:xmlhttp.open("GET","demo_get.asp",true);xmlhttp.send();//可能得到的是缓存的结果

    此时可以向url添加一个唯一的ID:xmlhttp.open("GET","demo_get.asp?t="+Math.random,true);xmlhttp.send();

    eg:

    <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.onreadystatechange=function()
    {
    if (xmlhttp.readyState==4 && xmlhttp.status==200)
    {
    document.getElementById("myDiv").innerHTML=xmlhttp.responseText;
    }
    }
    xmlhttp.open("GET","/ajax/demo_get.asp?t=" + Math.random(),true);
    xmlhttp.send();
    }
    </script>
    </head>
    <body>

    <h2>AJAX</h2>
    <button type="button" onclick="loadXMLDoc()">请求数据</button>
    <div id="myDiv"></div>

    </body>
    </html>

    如果希望通过GET发送消息,可以这样:

    xmlhttp.open("GET","demo_get2.asp?fname=Bill&lname=Gates",true);
    xmlhttp.send();

    POST请求:

    一个简单的POST请求:

    xmlhttp.open("POST","demo_post.asp",true);
    xmlhttp.send();

    如果需要像 HTML 表单那样 POST 数据,请使用 setRequestHeader() 来添加 HTTP 头。然后在 send() 方法中规定你希望发送的数据:

    xmlhttp.open("POST","ajax_test.asp",true);
    xmlhttp.setRequestHeader("Content-type","application/x-www-form-urlencoded");//CONTENT-TYPE:application/x-www-form-urlencoded含义是表示客户端提交给服务器文本内容的编码方式 是URL编码,即除了标准字符外,每字节以双字节16进制前加个“%”表示.setRequestHeader(header,value),向请求添加 HTTP 头。header: 规定头的名称,value: 规定头的值。
    xmlhttp.send("fname=Bill&lname=Gates");


    在以下情况中,请使用 POST 请求:

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

    其余情况一般使用GET方法。

      (3)、服务器响应

    使用XMLHttpRequest 对象的 responseText 或 responseXML 属性。

    responseText:获得字符串形式的响应数据。

    responseText 属性返回字符串形式的响应,因此可以这样使用:

    document.getElementById("myDiv").innerHTML=xmlhttp.responseText;

    responseXML:获得XML形式的响应数据。

      (4)、onreadystatechange事件

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

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

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

    onreadystatechange:存储函数(或函数名),每当 readyState 属性改变时,就会调用该函数。onreadystatechange 事件被触发 5 次(0 - 4),对应着 readyState 的每个变化。

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

    0: 请求未初始化

    1: 服务器连接已建立

    2: 请求已接收

    3: 请求处理中

    4: 请求已完成,且响应已就绪

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

    使用callback函数:以参数形式传递给另一个函数的函数。该函数调用应该包含 URL 以及发生 onreadystatechange 事件时执行的任务(每次调用可能不尽相同)。

    eg:

    function myFunction()
    {
    loadXMLDoc("ajax_info.txt",function()
      {
      if (xmlhttp.readyState==4 && xmlhttp.status==200)
        {
        document.getElementById("myDiv").innerHTML=xmlhttp.responseText;
        }
      });
    }
    showHint()函数:
    eg:
    function showHint(str)
    {
    var xmlhttp;
    if (str.length==0)
      {
      document.getElementById("txtHint").innerHTML="";
      return;
      }
    if (window.XMLHttpRequest)
      {// code for IE7+, Firefox, Chrome, Opera, Safari
      xmlhttp=new XMLHttpRequest();
      }
    else
      {// code for IE6, IE5
      xmlhttp=new ActiveXObject("Microsoft.XMLHTTP");
      }
    xmlhttp.onreadystatechange=function()
      {
      if (xmlhttp.readyState==4 && xmlhttp.status==200)
        {
        document.getElementById("txtHint").innerHTML=xmlhttp.responseText;
        }
      }
    xmlhttp.open("GET","gethint.asp?q="+str,true);
    xmlhttp.send();
    }

    源代码解释:

    如果输入框为空 (str.length==0),则该函数清空 txtHint 占位符的内容,并退出函数。

    如果输入框不为空,showHint() 函数执行以下任务:

    a.创建 XMLHttpRequest 对象

    b.当服务器响应就绪时执行函数

    c.把请求发送到服务器上的文件

    d.请注意我们向 URL 添加了一个参数 q (带有输入框的内容)

  • 相关阅读:
    假期学习01
    构建之法读后感(二)
    构建之法读后感(一)
    每日日报
    每日日报
    每日日报
    每日日报
    每日日报
    每周日报
    每日日报
  • 原文地址:https://www.cnblogs.com/wuxn/p/4743120.html
Copyright © 2020-2023  润新知