我的编程空间,编程开发者的网络收藏夹
学习永远不晚

js如何实现简单实用的AJAX

短信预约 -IT技能 免费直播动态提醒
省份

北京

  • 北京
  • 上海
  • 天津
  • 重庆
  • 河北
  • 山东
  • 辽宁
  • 黑龙江
  • 吉林
  • 甘肃
  • 青海
  • 河南
  • 江苏
  • 湖北
  • 湖南
  • 江西
  • 浙江
  • 广东
  • 云南
  • 福建
  • 海南
  • 山西
  • 四川
  • 陕西
  • 贵州
  • 安徽
  • 广西
  • 内蒙
  • 西藏
  • 新疆
  • 宁夏
  • 兵团
手机号立即预约

请填写图片验证码后获取短信验证码

看不清楚,换张图片

免费获取短信验证码

js如何实现简单实用的AJAX

这篇文章主要介绍了js如何实现简单实用的AJAX,具有一定借鉴价值,感兴趣的朋友可以参考下,希望大家阅读完这篇文章之后大有收获,下面让小编带着大家一起了解一下。

JS是什么

JS是JavaScript的简称,它是一种直译式的脚本语言,其解释器被称为JavaScript引擎,是浏览器的一部分,主要用于web的开发,可以给网站添加各种各样的动态效果,让网页更加美观。

具体如下:

//版权归属 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);  }}

感谢你能够认真阅读完这篇文章,希望小编分享的“js如何实现简单实用的AJAX”这篇文章对大家有帮助,同时也希望大家多多支持编程网,关注编程网行业资讯频道,更多相关知识等着你来学习!

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

js如何实现简单实用的AJAX

下载Word文档到电脑,方便收藏和打印~

下载Word文档

猜你喜欢

js如何实现简单实用的AJAX

这篇文章主要介绍了js如何实现简单实用的AJAX,具有一定借鉴价值,感兴趣的朋友可以参考下,希望大家阅读完这篇文章之后大有收获,下面让小编带着大家一起了解一下。JS是什么JS是JavaScript的简称,它是一种直译式的脚本语言,其解释器被
2023-06-08

如何用js实现简单轮播图

这篇文章主要介绍“如何用js实现简单轮播图”的相关知识,小编通过实际案例向大家展示操作过程,操作方法简单快捷,实用性强,希望这篇“如何用js实现简单轮播图”文章能帮助大家解决问题。1.实现功能:2.实现思路:(1)鼠标放到图片上,显示箭头,
2023-07-02

ajax如何实现简单的登录页面

小编给大家分享一下ajax如何实现简单的登录页面,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧!一.什么是ajaxAjax是一种无需重新加载整个网页,能够更新部分网
2023-06-08

JS如何实现简单的下雪特效

这篇文章主要介绍了JS如何实现简单的下雪特效,具有一定借鉴价值,感兴趣的朋友可以参考下,希望大家阅读完这篇文章之后大有收获,下面让小编带着大家一起了解一下。前言首先看看项目结构,一张雪花图片,一个.html文件和 jquery-1.4.2.
2023-06-22

JS如何实现简单Tab栏切换

这篇文章主要为大家展示了“JS如何实现简单Tab栏切换”,内容简而易懂,条理清晰,希望能够帮助大家解决疑惑,下面让小编带领大家一起研究并学习一下“JS如何实现简单Tab栏切换”这篇文章吧。具体内容如下要求:当鼠标点击上面相应的选项卡(tab
2023-06-29

js如何实现简单拼图游戏

这篇文章主要介绍了js如何实现简单拼图游戏的相关知识,内容详细易懂,操作简单快捷,具有一定借鉴价值,相信大家阅读完这篇js如何实现简单拼图游戏文章都会有所收获,下面我们一起来看看吧。HTML仅有一个id为game的div,并且没有编写css
2023-07-02

AJAX如何实现简单的注册页面异步

小编给大家分享一下AJAX如何实现简单的注册页面异步,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧!AJAX简介(1)AJAX = 异步 JavaScript 和
2023-06-08

CSS3+js如何实现简单的时钟特效

小编给大家分享一下CSS3+js如何实现简单的时钟特效,希望大家阅读完这篇文章之后都有所收获,下面让我们一起去探讨吧!什么是csscss是一种用来表现HTML或XML等文件样式的计算机语言,主要是用来设计网页的样式,使网页更加美化。它也是一
2023-06-09

JS如何实现简单的九宫格抽奖

本篇内容介绍了“JS如何实现简单的九宫格抽奖”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!结构
2023-07-02

编程热搜

  • Python 学习之路 - Python
    一、安装Python34Windows在Python官网(https://www.python.org/downloads/)下载安装包并安装。Python的默认安装路径是:C:\Python34配置环境变量:【右键计算机】--》【属性】-
    Python 学习之路 - Python
  • chatgpt的中文全称是什么
    chatgpt的中文全称是生成型预训练变换模型。ChatGPT是什么ChatGPT是美国人工智能研究实验室OpenAI开发的一种全新聊天机器人模型,它能够通过学习和理解人类的语言来进行对话,还能根据聊天的上下文进行互动,并协助人类完成一系列
    chatgpt的中文全称是什么
  • C/C++中extern函数使用详解
  • C/C++可变参数的使用
    可变参数的使用方法远远不止以下几种,不过在C,C++中使用可变参数时要小心,在使用printf()等函数时传入的参数个数一定不能比前面的格式化字符串中的’%’符号个数少,否则会产生访问越界,运气不好的话还会导致程序崩溃
    C/C++可变参数的使用
  • css样式文件该放在哪里
  • php中数组下标必须是连续的吗
  • Python 3 教程
    Python 3 教程 Python 的 3.0 版本,常被称为 Python 3000,或简称 Py3k。相对于 Python 的早期版本,这是一个较大的升级。为了不带入过多的累赘,Python 3.0 在设计的时候没有考虑向下兼容。 Python
    Python 3 教程
  • Python pip包管理
    一、前言    在Python中, 安装第三方模块是通过 setuptools 这个工具完成的。 Python有两个封装了 setuptools的包管理工具: easy_install  和  pip , 目前官方推荐使用 pip。    
    Python pip包管理
  • ubuntu如何重新编译内核
  • 改善Java代码之慎用java动态编译

目录