Ajax——Asynchronous JavaScript and XML
一、简介
- 异步的 JavaScript 和 XML
- 功能:
- AJAX 是与服务器交换数据并更新部分网页的艺术,在不重新加载整个页面的情况下
- AJAX 是一种用于创建快速动态网页的技术
- 为什么使用Ajax
- Google搜索建议
- 文档加载完更新,避免卡死
- 局部更新网页
二、XMLHttpRequqest
1. XHR创建对象
- 概述:
- 所有现代浏览器均支持 XMLHttpRequest 对象(IE5 和 IE6 使用 ActiveXObject)
- 创建对象
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");
}
2. XHR请求
- 向服务器发送请求,使用 XMLHttpRequest 对象的
open() 和 send()
方法
方法 | 描述 |
---|---|
open(method, url,async) | 规定请求的类型、URL 以及是否异步处理请求 method:请求的类型;GET 或 POST url:文件在服务器上的位置 async:true(异步)或 false(同步) |
send(string) | 将请求发送到服务器 string:仅用于 POST 请求 |
setRequestHeader(header,value) | 向请求添加 HTTP 头,仅用于POST请求 header: 规定头的名称 value: 规定头的值 |
2.1 GET和POST比较
- 与 POST 相比,GET 更简单也更快,并且在大部分情况下都能用。
- 然而,在以下情况中,请使用 POST 请求:
- 无法使用缓存文件(更新服务器上的文件或数据库)
- 向服务器发送大量数据(POST 没有数据量限制)
- 发送包含未知字符的用户输入时,POST 比 GET 更稳定也更可靠
2.1.1 GET请求
//简单的GET请求,可能得到的是缓存的结果:
xmlhttp.open("GET","demo_get.asp",true);
xmlhttp.send();
//避免读取缓存,应向 URL 添加一个唯一的 ID:
xmlhttp.open("GET","demo_get.asp?t=" + Math.random(),true);
xmlhttp.send();
//如果您希望通过 GET 方法发送信息,请向 URL 添加信息:
xmlhttp.open("GET","demo_get2.asp?fname=Bill&lname=Gates",true);
xmlhttp.send();
2.1.2 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");
xmlhttp.send("fname=Bill&lname=Gates");
2.2 url
- open() 方法的 url 参数是服务器上文件的地址
- 该文件可以是任何类型的文件(.txt, .xml),或者服务器脚本文件(.asp, .php)
2.3 async
- open() 方法的 async 参数用于指定是否使用Ajax
- XMLHttpRequest 对象用于 AJAX,则 async 参数必须设置为 true
- 通过 AJAX,JavaScript 无需等待服务器的响应,而是:
- 在等待服务器响应时执行其他脚本
- 当响应就绪后对响应进行处理
- 通过 AJAX,JavaScript 无需等待服务器的响应,而是:
- async=false 时,不要编写 onreadystatechange 函数
- 把代码放到 send() 语句后面
- 不推荐使用 async=false
3.服务器响应
属性 | 描述 |
---|---|
responseText | 获得字符串形式的响应数据 |
responseXML | 获得 XML 形式的响应数据 |
document.getElementById(“myDiv”).innerHTML=xmlhttp.responseText;
3.2 responseXML
//需要作为 XML 对象进行解析
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;
4. readyState
- 当请求被发送到服务器时,我们需要执行一些基于响应的任务, 每当
readyState
改变时,就会触发onreadystatechange
事件,readyState
属性存有XMLHttpRequest
的状态信息
属性 | 描述 |
---|---|
onreadystatechange | 存储函数(或函数名),每当 readyState 属性改变时,就会调用该函数 |
readyState | 存有 XMLHttpRequest 的状态。从 0 到 4 发生变化
|
status | 200: "OK" 404: 未找到页面 |
- 使用 Callback 函数
- 何时使用:网站上存在多个 AJAX 任务
<html>
<head>
<script type="text/javascript">
var xmlhttp;
function loadXMLDoc(url,cfunc)
{
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=cfunc;
xmlhttp.open("GET",url,true);
xmlhttp.send();
}
function myFunction()
{
loadXMLDoc("/ajax/test1.txt",function()
{
if (xmlhttp.readyState==4 && xmlhttp.status==200)
{
document.getElementById("myDiv").innerHTML=xmlhttp.responseText;
}
});
}
</script>
</head>
<body>
<div id="myDiv"><h2>Let AJAX change this text</h2></div>
<button type="button" onclick="myFunction()">通过 AJAX 改变内容</button>
</body>
</html>
Ajax 高级
1. Ajax ASP/PHP
可以请求.asp
或者.php
界面,完成其他任务
2. Ajax数据库
同样请求.asp
或者.php
界面,在后端完成数据库操作
3. Ajax XML文件
x=xmlhttp.responseXML.documentElement.getElementsByTagName(“CD”);