js实现简单实用的AJAX完整实例

所属分类: 网络编程 / AJAX相关 阅读数: 782
收藏 0 赞 0 分享

本文实例讲述了js实现简单实用的AJAX的方法。分享给大家供大家参考,具体如下:

//版权归属 WUJXPING
//ajax 1.2
//更新2012-2-20
//1、异步数据加载可以进行加载方式get,post的设定
//2、异步同步模式的属性设定
//3、数据加载自动超时设置
//4、***数据加载事件的添加,通过事件可以进行服务器数据的实时处理
//5、增加回调函数中用户自定义参数this.e
//6、增加ajax反复提交控制,只需将ajax对象定义为全局变量,每次提交都会进行等待上次提交的执行结果
//7、修改数据反复提交时XmlHttp对象被反复创建的问题
//8、修复重大BUG,多个AJAX事件覆盖问题
//服务器数据返回事件
ajax.prototype.ServerEven=function(Func){
  this.callback=new delegate(Func);//实例化
}
//创建异步处理对象
ajax.prototype.CreateXMLHttp=function(){
  if(this.XmlHttp!=null && typeof this.XmlHttp == "object")
    return this.XmlHttp;
  xmlhttpObj = ["Microsoft.XmlHttp","MSXML2.XmlHttp.5.0","MSXML2.XmlHttp.4.0","MSXML2.XmlHttp.3.0","MSXML2.XmlHttp"];
 //根据不同的浏览器创建XMLHttpRequest
 if(window.ActiveXObject){
   for(i=0;i<xmlhttpObj.length;i++){ //选择ie兼容版本
      try{
        this.XmlHttp = new ActiveXObject(xmlhttpObj[i]);
      }catch(err){
        continue;
      }
      if(this.XmlHttp)
        break;
    }
 }
 else if(window.XMLHttpRequest){
  this.XmlHttp=new XMLHttpRequest();
 }
  return this.XmlHttp;
 }
 //开始调用
ajax.prototype.Send=function(){
  if(this.isbusy)//ajax正忙
    return;
  this.isbusy=true;
 var xmlhtml=this.CreateXMLHttp(); //创建对象
  if(xmlhtml==null){
    this.isbusy=false
    if(this.callback!=null)
      this.callback.run("XMLHttpRequest Create Faild!",this.e);
    return;
  }
  var url=this.url;
  var _this=this;
  // 加随机数防止缓存
  if (url.indexOf("?") > 0)
    url += "&randnum=" + Math.random();
  else
    url += "?randnum=" + Math.random();
  xmlhtml.open(this.method,url,this.async);
 xmlhtml.setRequestHeader("Content-Type","application/x-www-form-urlencoded;charset=utf-8;");
  xmlhtml.setRequestHeader("Cache-Control","no-cache");
 xmlhtml.setRequestHeader("Connection","Keep-Alive");
  //开启定时进行超时等待
  var timer=setTimeout(function(){
    //if(xmlhtml.readyState!=4){
    xmlhtml.abort(); //取消本次传输
    _this.isbusy=false;
    if(_this.callback!=null)
      _this.callback.run("send timeout!",_this.e);
    clearTimeout(timer); //关闭定时器
  },this.timeout);
  if(this.async)//异步数据加载时状态变化与事件挂钩
    xmlhtml.onreadystatechange=function(){//接收服务器响应
      if(xmlhtml.readyState==4){//判断是否是完成状态
        if(xmlhtml.status==200){ //判断是否执行成功
          _this.isbusy=false;
          clearTimeout(timer); //关闭定时器
          if(_this.callback!=null)//开始触发服务器事件
            _this.callback.run(xmlhtml,_this.e);
        }
      }
    };
  try{
    xmlhtml.send(this.option);
  }catch(err){
    this.isbusy=false
    clearTimeout(timer); //关闭定时器
    alert(err);
    return;
  }
  if(!this.async){//同步数据加载时数据返回处理
    this.isbusy=false;
    clearTimeout(timer); //关闭定时器
    if(this.callback!=null)
      this.callback.run(xmlhtml,this.e);
  }
 }
 //创建ajax对象
function ajax(url){
  this.method="post";//设置数据提交方式
  this.async=true;//是否进行异步数据加载模式
  this.option="";  //请求的参数
  this.url=url;//请求的Url连接
  this.timeout=1000*60*1;//默认超时时间为1分钟
  this.e=null;//回调事件中用户自定义参数
  this.XmlHttp=null;//接收异步创建的对象防止反复创建
  this.isbusy=false//获取当前ajax的执行状态
  this.callback=null;//声明回调事件
  // 实现委托的类
  delegate=function (func){
   this.arr = new Array(); // 回调函数数组
   this.add = function(func){
    this.arr[this.arr.length] = func;
   };
   this.run = function(sender,e){
    for(var i=0;i<this.arr.length;i++){
     var func = this.arr[i];
     if(typeof func == "function"){
      func(sender,e); // 遍历所有方法以及调用
     }
    }
   }
   this.add(func);
  }
}

更多关于ajax相关内容感兴趣的读者可查看本站专题:《JavaScript中ajax操作技巧总结》及《jquery中Ajax用法总结

希望本文所述对大家ajax程序设计有所帮助。

更多精彩内容其他人还在看

ajax中文乱码问题解决方案

ajax中文乱码问题在中文中经常会出现这种问题,其实只要稍加注意就不会出现ajax中文乱码这回事情了,接下来为大家详细介绍下如何解决这类问题
收藏 0 赞 0 分享

jquery ajax实现批量删除具体思路及代码

回调函数,在请求完成后需要进行的操作:此处是把选中的checkbox去掉,接下来为大家详细介绍下,感兴趣的朋友可以参考下哈,希望对你有所帮助
收藏 0 赞 0 分享

JQuery+ajax实现批量上传图片(自写)

jquery+ajax方式实现单张图片上传的代码是可以搜的到,实现批量上传图片的程序却没搜索到于是自己写了个,感兴趣的朋友可以参考下
收藏 0 赞 0 分享

利用Ajax实现在脚本里传值实例介绍

Ajax实现在脚本里传值可以解决实际上的一些问题,本文实现了一下,感兴趣的朋友可以参考下,希望可以帮助到你
收藏 0 赞 0 分享

jQuery+Ajax实现表格数据不同列标题排序(为表格注入活力)

CSS也使得表格的布局越来越光彩耀人。但是,无论如何,都掩饰不了那些包装下的死板,接下来为大家介绍下让那些死板的数据 更具有可读性、可用性
收藏 0 赞 0 分享

jQery ajax——load()方法示例介绍

load(url,[data],[callback])url:加载的页面地址;data: 可选项,发送到服务器的数据,格式是key/value;callback:可选项,回调函数,示例代码如下
收藏 0 赞 0 分享

滑轮滚动到页面底部ajax加载数据配合jsonp实现探讨

滚动下拉到页面底部加载数据是很多瀑布流网站的做法,那来看看配合jsonp是如何实现的吧,小菜总结记录之用特在此与大家一起分享,感兴趣的朋友可以参考下哈
收藏 0 赞 0 分享

ajax 登录功能简单实现(未连接数据库)

未连接数据库下实现ajax 登录功能判断登陆成功与失败,喜欢ajax的朋友可以参考下哈,希望对大家有所帮助
收藏 0 赞 0 分享

AJAX和WebService实现邮箱验证(无刷新验证邮件地址是否合法)

首先在项目里面添加服务引用,验证 Email 地址是否正确(邮件地址合法、只是域名正确、邮件服务器没有找到等等)感兴趣的朋友可以参考下哈
收藏 0 赞 0 分享

AJAX和三层架构实现分页功能具体思路及代码

本文涉及到AJAX和三层架构方面的知识,在学习分页的同时也巩固了一下它们的相关知识,适合初学者的你
收藏 0 赞 0 分享
查看更多