超轻量级的Ajax库-ajax.js

一个非常轻量级的ajax库,简单实用,节省带宽。示例(http://users4.jabry.com/pengju/ajax.html)

主要用法:ajax(options).method(); options:一个对象,包含如下选项

url://数据源地址

method://请求方法[POST、HEAD...]

data://要发送给服务器的数据

async://是否是异步请求

timeout://请求超时,默认为十秒

cache://是否从缓存中取数据(如果浏览器已缓存)

onSuccess:请求成功并将结果作为参数调用的函数

onError;请求失败调用的函数

onComplete:请求完成调用的函数,无论成功与否

showStatus;以当前状态码为参数调用的函数

type:为本类型,如:txt、js、xml、html

一般情况下url是必需的;其余的可选 ,主要方法:

getText:function(fn)//取文本,请求成功后以获取的文本为参数调用fn函数

getXML:function(fn)//取XML文本,请求成功后以获取的XML文档根对象为参数调用fn函数

getScript:function(fn)//取JavaScript,请求成功后将获取的代码用eval执行后的结果为参数调用fn函数

getHTML:function(fn)//取HTML文本,请求成功后以获取的HTML文本为参数调用fn函数,与getText不同的是文本中的HTML标记可以被正常显示

oppendTo(obj)://将返回结果添加到指定的DOM对象上,如ajax({url:"get.jsp?data=xyz"}).getHTML().appendTo(document.body)

exe:function(options)//发送和接收请求结果的核心函数,options是一个对象,包含:

onSuccess:请求成功并将结果作为参数调用的函数

onError;请求失败调用的函数

onComplete:请求完成调用的函数,无论成功与否

showStatus;以当前状态码为参数调用的函数

type:为本类型,如:txt、js、xml、html




源代码:
(function(wnd,undef){
  var doc=wnd.document,OBJ="object",STR="string";
 
  var ajax=function(options){
  return new ajax.prototype.init(options);
  };
 
  function AjaxError(msg){
  this.name="Ajax错误";
  this.message=msg||"未知错误";
  }
 
  ajax.prototype={
  init:function(option){
  this[0]=this.create();//创建Ajax对象
  this[1]={
  url:option.url||"",//数据源地址
  method:option.method||"GET",//请求方法[POST、HEAD...]
  data:option.data||null,//要发送给服务器的数据
  async:option.async||true,//是否是异步请求
  type:option.type||"text",//返回数据后,将数据转换为指定的类型.(text,js,xml,html)
  timeout:option.timeout||10000,//请求超时,默认为十秒
  cache:option.cache||false,//是否从缓存中取数据(如果浏览器已缓存)
  onSuccess:option.onSuccess||function(result){},//请求成功后执行的函数(处理返回结果)
  onError:option.onError||function(){},//请求出错调用的函数
  onComplete:option.onComplete||function(){},//请求完成后(无论成功与否)都执行的函数
  showStatus:option.showStatus||function(){}//显示请求状态
  };

  fix(this[1]);
  return this;
  },
 
  create:function(){
  if(wnd.XMLHttpRequest==undef){
  wnd.XMLHttpRequest=function(){
  if(wnd.ActiveXObject){
  try{
  return new ActiveXObject("Msxml2.XMLHTTP");
  }catch(e){
  return new ActiveXObject("Microsoft.XMLHTTP");
  }
  }
  };
  }
  return new  XMLHttpRequest();
  },
  open:function(){
  try{
  this[0].open(this[1].method,this[1].url,this[1].async);
  if(/POST/i.test(this[1].method)){
  this[0].setRequestHeader("Content-Type","application/x-www-form-urlencoded");
  if(this[0].overrideMimeType)this[0].setRequestHeader("Connection","close");
  }
  }catch(e){throw new AjaxError(e.message)}
  return this;
  },
  send:function(){
  try{this[0].send(this[1].data);}catch(e){throw new AjaxError(e.message);}
  return this;
  },
  stop:function(){
  try{this[0].abort();}catch(e){throw new AjaxError(e.message)}
  return this;
  },
  getText:function(fn){return this.exe({"onSuccess":fn,"type":"text"});},//fn可选
  getXML:function(fn){return this.exe({"onSuccess":fn,"type":"xml"});},
  getScript:function(fn){return this.exe({"onSuccess":fn,"type":"js"});},
  getHTML:function(fn){return this.exe({"onSuccess":fn,"type":"html"});},
  exe:function(options){
  if(options.onSuccess)this[1].onSuccess=options.onSuccess;
  if(options.onError)this[1].onError=options.onError;
  if(options.onComplete)this[1].onComplete=options.onComplete;
  if(options.showStatus)this[1].showStatus=options.showStatus;
  if(options.type)this[1].type=options.type;
  try{
 
  var isTimeout=false,cur=this.open();
 
  var timer=setTimeout(function(){
  isTimeout=true;
  cur.stop();
  cur[1].onError(new AjaxError("请求超时"));
  },cur[1].timeout);
 
  this[0].onreadystatechange=function(){
  cur[1].showStatus(cur[0].readyState);
  if(cur[0].readyState==4&&!isTimeout){
 
try{
if(isOK(cur[0])){//成功完成
var t=httpData(cur[0],cur[1].type);
 
if(cur.to&&cur.to.length>0){
for(var i=0;i<cur.to.length;i++){
if(cur.to[i].type&&cur.to[i].type=="html")
cur.to[i].target.innerHTML+=t;
else cur.to[i].target.appendChild(doc.createTextNode(t));
}
}
cur[1].onSuccess(t);
}
else{cur[1].onError(new AjaxError("请求未成功完成"));}

}catch(et){
cur[1].onError(new AjaxError(et.message));
}finally{
cur[1].onComplete();
cur[0]=null;
clearTimeout(timer);


  }
  };
 
  this.send();
 
  }catch(e){
  this[1].onError(new AjaxError(e.message));
  }finally{
  return this;
  }
 
  },

  appendTo:function(target){//将返回的结果加到指定的目标[id或DOM对象]
    if(!this.to)this.to=[];
    this.to.push({"target":$(target),"type":this[1].type});
  return this;
  }
  };//end prototype
ajax.prototype.init.prototype=ajax.prototype;

ajax.parseToQueryString=function(obj){//将数组或对象序列化
if(typeof obj===STR)return obj;
var s=[];
if(obj instanceof Array){//假定为数组
for(var i=0;i<obj.length;i++)
s.push(obj[i].name||i+"="+obj[i]);
}
else{
for(var j in obj) s.push(j+"="+obj[j]);
}
return s.join("&");
} ;

ajax.parseToObject=function(str){//将查询字符串转化成对象
if(typeof str==OBJ)return str;
var set={};
str=str.split("&");
var item;
for(var i=0;i<str.length;i++){
if(str[i].indexOf("=")>0){
item=str[i].split("=");
set[item[0]]=item[1];
}
}
return set;
};

var fix=function(p){
if(p.data){p.data=ajax.parseToQueryString(p.data);}
if(p.method.toUpperCase()=="GET"&&p.data){p.url=append(p.url,p.data);}
if(!p.cache){
p.url=append(p.url,"abkjfjk="+(new Date().getTime())+"jrejhjdd");
}
};

var $=function(id){return typeof id===OBJ?id:doc.getElementById(id);};

function isOK(r){
try{return !r.status&&location.protocol=="file:"
||(r.status>=200&&r.status<300)
||r.status==304
||navigator.userAgent.indexOf("Safari")>=0&&r.status==undef;
}catch(e){}
return false;
}

function httpData(r,type){
var res=type;
if(!res){
var ct=r.getResponseHeader("Content-Type");
if(/xml/i.test(ct)) res="xml";
else if(/JavaScript/i.test(ct))res="js";
else res="";
}
switch(res){
case "xml":return r.responseXML.documentElement;
case "js":return eval("("+r.responseText+")");
default:return r.responseText;
}
}


function append(url,param){
if(url.indexOf("?")<0){return url+"?"+param;}
else{
if(/\?$/.test(url)){return url+param;}
else{return url+"&"+param;}
}
}


  wnd.ajax=ajax;
  })(window);

你可能感兴趣的:(JavaScript,xml,Ajax,cache,prototype)