Ajax的流程大致为:
一.初始化XMLHttpRequest对象
代码大致如下,可以相应修改:
var xmlhttp; //对象名任意起
if (window.XMLHttpRequest)
{xmlhttp=new XMLHttpRequest(); // for IE7+, Firefox, Chrome, Opera, Safari
}
else
{xmlhttp=new ActiveXObject("Microsoft.XMLHTTP"); // for IE6, IE5老版浏览器
}
二.向服务器发送请求
需要用到XMLHttpRequest对象的open()和send()方法
1.创建一个与服务器的连接,使用open()方法,需要指定发送请求的方式(GET或POST),格式为xmlhttp.open("get",url,true);
2.向服务器发送请求,使用XMLHttpRequest对象的send()方法,格式为:xmlhttp.send();
三.处理服务器响应
XMLHttpRequest对象提供了两个返回服务器响应的属性:responseText属性和responseXML属性。
代码大致为:
xmlhttp.onreadystatechange=function()
{
if (xmlhttp.readyState==4){
if(xmlhttp.status==200){
document.getElementById("aa").innerHTML=xmlhttp.responseText;
}else{
alert("您所请求的页面有错误!")
}
}
}
最后附上一个完整的例子,来源于w3c网: http://www.w3school.com.cn/tiy/t.asp?f=ajax_httprequest_js
<html>
<head>
<script type="text/javascript">
var xmlhttp;
function loadXMLDoc(url)
{
xmlhttp=null;
if (window.XMLHttpRequest)
{// code for IE7, Firefox, Opera, etc.
xmlhttp=new XMLHttpRequest();
}
else if (window.ActiveXObject)
{// code for IE6, IE5
xmlhttp=new ActiveXObject("Microsoft.XMLHTTP");
}
if (xmlhttp!=null)
{
xmlhttp.onreadystatechange=state_Change;
xmlhttp.open("GET",url,true);
xmlhttp.send(null);
}
else
{
alert("Your browser does not support XMLHTTP.");
}
}
function state_Change()
{
if (xmlhttp.readyState==4)
{// 4 = "loaded"
if (xmlhttp.status==200)
{// 200 = "OK"
document.getElementById('A1').innerHTML=xmlhttp.status;
document.getElementById('A2').innerHTML=xmlhttp.statusText;
document.getElementById('A3').innerHTML=xmlhttp.responseText;
}
else
{
alert("Problem retrieving XML data:" + xmlhttp.statusText);
}
}
}
</script>
</head>
<body>
<h2>Using the HttpRequest Object</h2>
<p><b>Status:</b>
<span id="A1"></span>
</p>
<p><b>Status text:</b>
<span id="A2"></span>
</p>
<p><b>Response:</b>
<br /><span id="A3"></span>
</p>
<button οnclick="loadXMLDoc('/example/xmle/note.xml')">Get XML</button>
</body>
</html>