日期:2014-05-16  浏览次数:20409 次

求教一段ajax重构的代码
var net=new Object(); //定义一个全局变量net
//编写构造函数
net.AjaxRequest=function(url,onload,onerror,method,params){
  this.req=null;
  this.onload=onload;
  this.onerror=(onerror) ? onerror : this.defaultError;
  this.loadDate(url,method,params);
}
//编写用于初始化XMLHttpRequest对象并指定处理函数,最后发送HTTP请求的方法
net.AjaxRequest.prototype.loadDate=function(url,method,params){
  if (!method){ //设置默认为的请求方式为GET
  method="GET";
  }
  if (window.XMLHttpRequest){ // Mozilla……等非IE浏览器
  this.req=new XMLHttpRequest(); //创建XMLHttpRequest对象
  } else if (window.ActiveXObject){ //IE浏览器
try{
this.req=new ActiveXObject("Msxml2.XMLHTTP"); //创建XMLHttpRequest对象
}catch(e){
try{
this.req=new ActiveXObject("Microsoft.XMLHTTP"); //创建XMLHttpRequest对象
}catch(e){}
}
  }
  if (this.req){
  try{
  var loader=this;
  //指定回调函数
  this.req.onreadystatechange=function(){
  net.AjaxRequest.onReadyState.call(loader);
  }
  this.req.open(method,url,true); //创建与服务器的连接
if(method=="POST"){ //当发送POST请求时,设置请求头
this.req.setRequestHeader("Content-Type","application/x-www-form-urlencoded"); 
}
  this.req.send(params); //向服务器发送请求
  }catch (err){
  this.onerror.call(this); //调用错误处理函数
  }
  }
}

//重构回调函数
net.AjaxRequest.onReadyState=function(){
  var req=this.req;
  var ready=req.readyState; //获取请求状态
  if (ready==4){
  if (req.status==200 ){
  this.onload.call(this); //调用回调函数
  }else{
  this.onerror.call(this); //调用错误处理函数
  }
  }
}
//重构默认的错误处理函数
net.AjaxRequest.prototype.defaultError=function(){
  alert("错误数据\n\n回调状态:"+this.req.readyState+"\n状态: "+this.req.status);
}
这是在《JAVA WEB开发实战宝典》中的“ajax重构”这一章看到的一段js程序,基本没怎么看懂。类似这种语句:var loader=this和net.AjaxRequest.prototype.loadDate=function(url,method,params)有点搞不明白,prototype属性不是应用在对象上面的吗(比如:对象.prototype属性=某个方法)?怎么给net对象的AjaxRequest方法加上一个prototype属性呢?还有就是被if判断语句部分中的:if(this。req)、if(!method)这些括号里边的东西搞得一头雾水、另外,对call()函数基本也就是了解个语法恳请结合本例解释解释,最后就是js里边的this看到小弟好纠结...最好就是能逐行指教小弟了。如需整个项目(就是实现一个级联下拉列表,改变省份下拉列表的值,自动显示该省份对应的县市)的源码请留QQ或邮箱,谢过各位~

------解决方案--------------------
var loader=this; // 不就是声明一个变量,保存this 指针吗
 
net.AjaxRequest 就是一个对象

if(v) v 不是 0 "" false null undefined 返回true