日期:2014-05-16 浏览次数:20345 次
21.XMLHttpRequest对象详解
XMLHttpRequest包含了一些基本的属性和方法,XMLHttpRequest正是通过这些属性和方法与服务器通信的。Ajax则依赖于XMLHttpRequest来完成与服务器的通信。
XMLHttpRequest的方法:
abort():停止发送当前请求
getAllResponseHeaders():获取服务器返回的全部响应头
getResponseHeader():根据响应头的名字,获取对应的响应头
open("method","URL","asyncFlag"):建立与服务器URL的连接,并设置请求的方法,以及是否使用异步请求
XMLHttpRequest的属性:
onreadystatechange:该属性用于指定XMLHttpRequest对象状态改变时的事件处理函数
readyState:XMLHttpRequest对象的处理状态
responseText:获取服务器的相应文本
responseXML:获取服务器的XML文档对象
status:该属性是服务器的返回的状态码,只有当服务器的相应已经完成时,才会有该状态码
statusText:是服务器返回的状态文本信息,只有当服务器的相应已经完成时,才会有该状态文本信息
?
XMLHttpRequest对象的几种状态:
0:XMLHttpRequest对象还没有完成初始化
1:XMLHttpRequest对象开始发送请求
2:XMLHttpRequest对象的请求发送完成
3:XMLHttpRequest对象开始读取服务器的响应
4:XMLHttpRequest对象读取服务器响应结束
?
服务器常用的状态码及其对应的含义:
200:服务器相应正常
400:无法找到请求的资源
404:需要访问的资源不存在
500:服务器内部错误
?
//判断处理服务器响应的时机是否成熟,响应完成且响应正常
if(xmlrequest.readyState == 4){
?????? if(xmlrequest.status == 200){
???????????? //信息已经成功返回,开始处理信息???
???????}else{
???????????? //页面不正常信息
?????? }
}
?
22.Ajax必须解决的问题
跨浏览器问题
安全性问题:通常建议JavaScript只能读取和修改同源文档的属性,这种策略称为同源策略(Same Origin Policy,简称SOP)
性能问题:
for(;;),while(),for(in):for(in)效率最差,因为它需要查询Hash键
如果需要遍历数组,应该先缓存数组长度
尽量少用eval
尽量使用+=、-=、*=、\=
当需要将数字转换成字符时,采用如下方式:""+1
当需要将浮点数转换成整形时,应该使用Math.floor()或者Math.round(),而不是使用parseInt
尽量使用JSON格式来创建对象
当使用数组时,也尽量使用JSON格式的语法
对字符串进行循环操作,例如替换、查找,应使用正则表达式
最后一个基本的原则,对于大的JavaScript对象,因为创建时时间和空间的开销都比较大,因此应该尽量考虑采用缓存,考虑使用池的技术管理。
?
xmlrequestPool.js
//使用literal语法定义一个对象XMLHttp
var XMLHttp =
{
????? //定义第一个属性,该属性用于缓存XMLHttpRequest对象的数组
????? XMLHttpRequestPool:[],
????? //对象的第一个方法,该方法用于返回一个XMLHttpRequest对象
????? getInstance:function()
????? {
????????????? //从XMLHttpRequest的对象池中取出一个闲置的对象
????????????? for(var i = 0; i < this.XMLHttpRequestPool.length; i++)
???????????? {
??????????????????? //readyState为0或者为4,都表示当前的XMLHttpRequest对象为闲置的对象
??????????????????? if(this.XMLHttpRequestPool[i].readyState==0||this.XMLHttpRequestPool[i].readyState==4)
??????????????????? {
?????????????????????????? return this.XMLHttpRequestPool[i];
??????????????????? }
?????????????}
?????????????//如果没有空闲的,将再次创建一个新的XMLHttpRequest对象
?????????????this.XMLHttpRequestPool[this.XMLHttpRequestPool.length] = this.createXMLHttpRequest();
???????????? //返回刚刚创建的XMLHttpRequest对象
???????????? return this.XMLHttpRequestPool[this.XMLHttpRequestPool.length-1];?
??????},
????? //创建新的XMLHttpRequest对象
????? createXMLHttpRequest:function()
????? {
?????????????//DOM2浏览器
???????????? var objXMLHttp = new XMLHttpRequest();
???????????? //IE浏览器
???????????? var objXMLHttp = new ActiveXObject('xxx');
???????????? return objXMLHttp;
??????},
????? //定义对象的第三个方法:发送请求(发送[POST,GET],地址,数据,回调函数)
????? sendRequest:function(method,url,data,callback)
????? {
???????????? var objXMLHttp = this.getInstance();
???????????? with(objXMLHttp)
???????????? {
??????????????????? try{
????????????????????????? //增加一个额外的random请求参数,用于防止IE缓存服务器相应
????????????????????????? if(url.indexOf("?")>0)
????????????????????????? {
???????????????????????????????? url += "&random=" + Math.random();
??????????????????????????}else
??????????????????????????{
???????????????????????????????? url += "?random=" + Math.random();
??????????????????????????}
????????????????????????? //打开与服务器的连接
????????????????????????? open(method,url,true);
??????????????????