XMLHttpRequest 是 AJAX 的基础,用于在后台与服务器交换数据。这意味着能够在不从新加载整个网页的状况下,对网页的某部分进行更新。php
全部现代浏览器均支持 XMLHttpRequest 对象(IE5 和 IE6 使用 ActiveXObject),全部现代浏览器(IE7+、Firefox、Chrome、Safari 及 Opera)均内建 XMLHttpRequest 对象。XMLHttpRequest在不一样浏览器上的实现是兼容的,因此能够用一样的方式访问XMLHttpRequest实例的属性和方法,而不论这个实例建立的方法是什么。html
为了每次写Ajax的时候都节省一点时间,能够把对象检测的内容打包成一个可复用的函数:node
function getHTTPObject(){
var xhr=false;
if(window.XMLHttpRequest){
xhr=new XMLHttpRequest();
}else if(window.ActiveXObject()){
xhr=new ActiveXObject("Microsoft.XMLHTTP");
}
return xhr;
}
对window.XMLHttpRequest的调用会返回一个对象或null,if语句会把调用返回的结果看做是true或false(若是返回对象则为true,返回null则为false)。若是XMLHttpRequest对象存在,则把 xhr 的值设为该对象的新实例。若是不存在,就去检测 ActiveObject 的实例是否存在,若是答案是确定的,则把微软 XMLHTTP 的新实例赋给 xhr。ajax
如需将请求发送到服务器,咱们使用 XMLHttpRequest 对象的 open() 和 send() 方法:数据库
xmlhttp.open("GET","ajax_info.txt",true);
xmlhttp.send();
open(method,url,async) 规定请求的类型、URL 以及是否异步处理请求。浏览器
send(string) 将请求发送到服务器。缓存
在如下状况中,请使用 POST 请求:服务器
如下是一个简单的 GET 请求:app
xmlhttp.open("GET","demo_get.html",true);
xmlhttp.send();
可能获得的是缓存的结果,为了不这种状况,请向 URL 添加一个惟一的 ID:dom
xmlhttp.open("GET","demo_get.html?t=" + Math.random(),true);
xmlhttp.send();
若要经过 GET 方法发送信息,向 URL 添加信息:
xmlhttp.open("GET","demo_get2.html?fname=Henry&lname=Ford",true); xmlhttp.send();
如下是一个简单的 POST 请求:
xmlhttp.open("POST","demo_post.html",true);
xmlhttp.send();
若是须要像 HTML 表单那样 POST 数据,使用 setRequestHeader() 来添加 HTTP 头。而后在 send() 方法中规定要发送的数据:
xmlhttp.open("POST","ajax_test.html",true); xmlhttp.setRequestHeader("Content-type","application/x-www-form-urlencoded"); xmlhttp.send("fname=Henry&lname=Ford");
setRequestHeader(header,value) 向请求添加 HTTP 头。
url - 服务器上的文件的地址,该文件能够是任何类型的文件,好比 .txt 和 .xml,或者服务器脚本文件,好比 .asp 和 .php (在传回响应以前,可以在服务器上执行任务)。
XMLHttpRequest 对象若是要用于 AJAX 的话,其 open() 方法的 async 参数必须设置为 true
经过 AJAX,JavaScript 无需等待服务器的响应,而是:
当使用 async=true 时,请规定在响应处于 onreadystatechange 事件中的就绪状态时执行的函数
<!DOCTYPE html> <html> <head> <meta charset="utf-8"> <script> function loadXMLDoc() { var xmlhttp; if (window.XMLHttpRequest) { // IE7+, Firefox, Chrome, Opera, Safari 浏览器执行代码 xmlhttp=new XMLHttpRequest(); } else { // 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","/try/ajax/ajax_info.txt",true); xmlhttp.send(); } </script> </head> <body> <div id="myDiv"><h2>使用 AJAX 修改该文本内容</h2></div> <button type="button" onclick="loadXMLDoc()">修改内容</button> </body </html>
JavaScript 会等到服务器响应就绪才继续执行。若是服务器繁忙或缓慢,应用程序会挂起或中止。
注意:当使用 async=false 时,请不要编写 onreadystatechange 函数 - 把代码放到 send() 语句后面便可:
function loadXMLDoc()
{
var xmlhttp;
if (window.XMLHttpRequest)
{
// IE7+, Firefox, Chrome, Opera, Safari 浏览器执行代码
xmlhttp=new XMLHttpRequest();
}
else
{
// IE6, IE5 浏览器执行代码
xmlhttp=new ActiveXObject("Microsoft.XMLHTTP");
}
xmlhttp.open("GET","/try/ajax/ajax_info.txt",false);
xmlhttp.send();
document.getElementById("myDiv").innerHTML=xmlhttp.responseText;
}
如需得到来自服务器的响应,请使用 XMLHttpRequest 对象的 responseText 或 responseXML 属性。
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();
xmlhttp.onreadystatechange=function() { if (xmlhttp.readyState==4 && xmlhttp.status==200) { 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; } } xmlhttp.open("GET","cd_catalog.xml",true); xmlhttp.send();
当请求被发送到服务器时,须要执行一些基于响应的任务。每当 readyState 改变时,就会触发 onreadystatechange 事件。在 onreadystatechange 事件中,咱们规定当服务器响应已作好被处理的准备时所执行的任务。onreadystatechange 事件被触发 5 次(0 - 4),对应着 readyState 的每一个变化。
readyState 属性存有 XMLHttpRequest 的状态信息。下面是 XMLHttpRequest 对象的三个重要的属性:
当 readyState 等于 4 且状态为 200 时,表示响应已就绪:
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();
callback 函数是一种以参数形式传递给另外一个函数的函数。
若是您的网站上存在多个 AJAX 任务,那么您应该为建立 XMLHttpRequest 对象编写一个标准的函数,并为每一个 AJAX 任务调用该函数。
该函数调用应该包含 URL 以及发生 onreadystatechange 事件时执行的任务(每次调用可能不尽相同):
function loadXMLDoc(url)
{
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('A1').innerHTML=xmlhttp.status;
document.getElementById('A2').innerHTML=xmlhttp.statusText;
document.getElementById('A3').innerHTML=xmlhttp.responseText;
}
}
xmlhttp.open("GET",url,true);
xmlhttp.send();
}