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 (带有输入框的内容)