本文实例讲述了javascript实现简单的ajax功能封装。分享给大家供大家参考,具体如下:
function ajax(obj){
var xhr = (function (){//获取xhr对象,为了兼容ie6所以进行了重新封装
if(typeof XMLHttpRequest !='undefined') {
return new XMLHttpRequest();
}else if(typeof ActiveXObject !='undefined') {
var version = [
'MSXML2.XMLHttp6.0',
'MSXML2.XMLHttp3.0',
'MSXML2.XMLHttp'
]
for(var i in version) {
try{
return new ActiveXObject(version[i]);
break;
}catch(e){
//捕获错误进行然后跳出继续循环
}
}
}else{
throw new Error("您的系统或浏览器不支持XHR对象!");
}
})();//获取xhr对象
//默认true开启异步(异步和同步的主要区别是异步在请求的时候后面的脚本可以继续运行,同步的话必须运行完ajax然后才能运行其后面的脚本)
if(obj.async === true) {
xhr.onreadystatechange = function() {
if(xhr.readyState ==4) {
callback(xhr.responseText);
}
}
}
var arr=[] ;
for(var i in obj.data) {arr.push(encodeURIComponent(i)+'='+encodeURIComponent(obj.data[i]));}
obj.data = arr.join('&'); //这一步要注意一下,不管是get/post 方式提交都必须要对传进来的obj.data进行格式化 最后转化成的格式name=zhang&age=26&wedding=no
if(obj.method === 'get') {//通过get方式请求的
obj.url = obj.url.indexOf('?') ==-1 ? obj.url+'?rand='+Math.random()+'&'+obj.data : obj.url+'rand='+Math.random()+'&'+obj.data;
xhr.open(obj.method,obj.url,obj.async);
xhr.send(null);
}
if(obj.method === 'post') {//通过post方式请求的
obj.url =obj.url+'?rand='+Math.random();
xhr.open(obj.method,obj.url,obj.async);
xhr.setRequestHeader('Content-Type', 'application/x-www-form-urlencoded');//这是对请求头部的类型重设,post的请求必须要重设;
xhr.send(obj.data);
}
//false开启同步
if(obj.async === false) {callback(xhr.responseText);}
function callback (returnTxt) {
if(xhr.status == 200){
obj.success(returnTxt);
}else {
alert('获取数据错误!错误代号:' + xhr.status + ',错误信息:' + xhr.statusText);
}
}
}
更多关于JavaScript相关内容感兴趣的读者可查看本站专题:《JavaScript中ajax操作技巧总结》、《JavaScript错误与调试技巧总结》、《JavaScript数据结构与算法技巧总结》、《JavaScript遍历算法与技巧总结》及《JavaScript数学运算用法总结》
希望本文所述对大家JavaScript程序设计有所帮助。
# javascript
# ajax
# 封装
# 原生javascript实现的ajax异步封装功能示例
# 原生js仿jquery实现对Ajax的封装
# 用原生JS对AJAX做简单封装的实例代码
# 浅析jQuery Ajax通用js封装
# 原生JS封装ajax 传json
# str
# excel文件上传提交表单(推荐)
# 原生JS封装Ajax插件(同域、jsonp跨域)
# js实现对ajax请求面向对象的封装
# 原生Javascript封装的一个AJAX函数分享
# js锁屏解屏通过对$.ajax进行封装实现
# JavaScript 联动的无限级封装类
# 数据采用非Ajax方式
# 随意添加联动
# JavaScript 封装Ajax传递的数据代码
# 一个AJAX自动完成功能的js封装源码[支持中文]
# 这是
# 您的
# 相关内容
# 遍历
# 感兴趣
# 数据结构
# 要注意
# 给大家
# 不支持
# 要对
# 更多关于
# 错误信息
# 所述
# 程序设计
# 转化成
# 进行了
# 操作技巧
# 都必须
# 必须要
# 讲述了
相关文章:
建站主机无法访问?如何排查域名与服务器问题
如何通过远程VPS快速搭建个人网站?
网站制作的步骤包括,正确网址格式怎么写?
建站上传速度慢?如何优化加速网站加载效率?
山东云建站价格为何差异显著?
专业企业网站设计制作公司,如何理解商贸企业的统一配送和分销网络建设?
如何选择美橙互联多站合一建站方案?
网站制作哪家好,cc、.co、.cm哪个域名更适合做网站?
如何注册花生壳免费域名并搭建个人网站?
GML (Geography Markup Language)是什么,它如何用XML来表示地理空间信息?
成都网站制作报价公司,成都工业用气开户费用?
建站之星导航配置指南:自助建站与SEO优化全解析
长沙做网站要多少钱,长沙国安网络怎么样?
专业网站建设制作报价,网页设计制作要考什么证?
如何在云主机快速搭建网站站点?
网站制作新手教程,新手建设一个网站需要注意些什么?
如何在阿里云虚拟主机上快速搭建个人网站?
利用JavaScript实现拖拽改变元素大小
网站海报制作教学视频教程,有什么免费的高清可商用图片网站,用于海报设计?
山东网站制作公司有哪些,山东大源集团官网?
专业网站制作服务公司,有哪些网站可以免费发布招聘信息?
如何在局域网内绑定自建网站域名?
建站之星上传入口如何快速找到?
建站之星免费模板:自助建站系统与智能响应式一键生成
网站制作专业公司有哪些,如何制作一个企业网站,建设网站的基本步骤有哪些?
标准网站视频模板制作软件,现在有哪个网站的视频编辑素材最齐全的,背景音乐、音效等?
阿里云网站搭建费用解析:服务器价格与建站成本优化指南
整人网站在线制作软件,整蛊网站退不出去必须要打我是白痴才能出去?
如何在服务器上配置二级域名建站?
微信网站制作公司有哪些,民生银行办理公司开户怎么在微信网页上查询进度?
微信h5制作网站有哪些,免费微信H5页面制作工具?
如何制作网站标识牌,动态网站如何制作(教程)?
如何快速生成ASP一键建站模板并优化安全性?
教程网站设计制作软件,怎么创建自己的一个网站?
合肥做个网站多少钱,合肥本地有没有比较靠谱的交友平台?
如何彻底卸载建站之星软件?
,网站推广常用方法?
如何在云主机上快速搭建多站点网站?
,在苏州找工作,上哪个网站比较好?
赚钱网站制作软件,建一个网站怎样才能赚钱?是如何盈利的?
Android使用GridView实现日历的简单功能
python的本地网站制作,如何创建本地站点?
如何快速配置高效服务器建站软件?
济南企业网站制作公司,济南社保单位网上缴费步骤?
建站之星安全性能如何?防护体系能否抵御黑客入侵?
南宁网站建设制作定制,南宁网站建设可以定制吗?
企业在线网站设计制作流程,想建设一个属于自己的企业网站,该如何去做?
网站制作需要会哪些技术,建立一个网站要花费多少?
建站之星微信建站一键生成小程序+多端营销系统
如何通过IIS搭建网站并配置访问权限?
*请认真填写需求信息,我们会在24小时内与您取得联系。