AJAX = 异步 JavaScript 和 XML。

AJAX 是一种用于创建快速动态网页的技术。

通过在后台与服务器进行少量数据交换,AJAX 可以使网页实现异步更新。这意味着可以在不重新加载整个网页的情况下,对网页的某部分进行更新。

传统的网页(不使用 AJAX)如果需要更新内容,必需重载整个网页面。

  1. variable=new XMLHttpRequest(); //创建XMLHttpRequest

    对于老版本浏览器,可能会不支持X
    MLHttpRequest,这时候需要
  1. variable=new ActiveXObject("Microsoft.XMLHTTP");


  1. var xmlhttp;
  2. if (window.XMLHttpRequest)
  3. {// code for IE7+, Firefox, Chrome, Opera, Safari
  4. xmlhttp=new XMLHttpRequest();
  5. }
  6. else
  7. {// code for IE6, IE5
  8. xmlhttp=new ActiveXObject("Microsoft.XMLHTTP");
  9. }
  1.  

open(method,url,async)

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

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

send(string)

将请求发送到服务器。

  • string:仅用于 POST 请求
  1. xmlhttp.open("GET","test1.txt",true);
  2. xmlhttp.send();

当文件非常大的时候就需要使用post,并且post比get更稳定

setRequestHeader(header,value)

向请求添加 HTTP 头。

  • header: 规定头的名称
  • value: 规定头的值 

(这个setRequestHeader然我联想到,python的request.get())

open() 方法的 url 参数是服务器上文件的地址:

  1. xmlhttp.open("GET","ajax_test.asp",true);
    该文件可以是任何类型的文件,比如 .txt .xml,或者服务器脚本文件,比如 .asp .php (在传回响应之前,能够在服务器上执行任务)。

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

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

综合上面知识点,我们可以分析以下代码:

  1. function loadXMLDoc()
  2. {
  3. var xmlhttp;
  4. if (window.XMLHttpRequest){// code for IE7+, Firefox, Chrome, Opera, Safari
  5. xmlhttp=new XMLHttpRequest();
  6. }
  7. else { // code for IE6, IE5
  8. xmlhttp=new ActiveXObject("Microsoft.XMLHTTP");
  9. } //这里整个条件判断都是用来申请异步内容
  10. xmlhttp.onreadystatechange=function(){
  11. if (xmlhttp.readyState==4 && xmlhttp.status==200){
  12. document.getElementById("myDiv").innerHTML=xmlhttp.responseText; //获得字符串响应,并且在id="myDiv"下显示
  13. }
  14. }
  15. xmlhttp.open("GET","/ajax/test1.txt",true); //与服务器进行交互
  16. xmlhttp.send();
  17. }

 

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

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

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

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

readyState:

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

  • 0: 请求未初始化
  • 1: 服务器连接已建立
  • 2: 请求已接收
  • 3: 请求处理中
  • 4: 请求已完成,且响应已就绪

status:

200: “OK”

404: 未找到页面

 

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

  1. xmlhttp.onreadystatechange=function()
  2. {
  3. if (xmlhttp.readyState==4 && xmlhttp.status==200)
  4. {
  5. document.getElementById("myDiv").innerHTML=xmlhttp.responseText;
  6. }
  7. }

 

版权声明:本文为ZQUACM-875180305原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接和本声明。
本文链接:https://www.cnblogs.com/ZQUACM-875180305/p/9598715.html