本文实例讲述了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封装源码[支持中文]
# 这是
# 您的
# 相关内容
# 遍历
# 感兴趣
# 数据结构
# 要注意
# 给大家
# 不支持
# 要对
# 更多关于
# 错误信息
# 所述
# 程序设计
# 转化成
# 进行了
# 操作技巧
# 都必须
# 必须要
# 讲述了
相关文章:
如何在万网ECS上快速搭建专属网站?
如何自己制作一个网站链接,如何制作一个企业网站,建设网站的基本步骤有哪些?
如何在Golang中实现微服务服务拆分_Golang微服务拆分与接口管理方法
如何在腾讯云免费申请建站?
定制建站流程步骤详解:一站式方案设计与开发指南
如何通过智能用户系统一键生成高效建站方案?
韩国网站服务器搭建指南:VPS选购、域名解析与DNS配置推荐
TestNG的testng.xml配置文件怎么写
Bpmn 2.0的XML文件怎么画流程图
如何通过山东自助建站平台快速注册域名?
建站之星安装后界面空白如何解决?
rsync同步时出现rsync: failed to set times on “xxxx”: Operation not permitted
如何在IIS中配置站点IP、端口及主机头?
建站之星北京办公室:智能建站系统与小程序生成方案解析
深圳网站制作公司好吗,在深圳找工作哪个网站最好啊?
专业型网站制作公司有哪些,我设计专业的,谁给推荐几个设计师兼职类的网站?
如何基于PHP生成高效IDC网络公司建站源码?
国美网站制作流程,国美电器蒸汽鍋怎么用官方网站?
建站之星五站合一营销型网站搭建攻略,流量入口全覆盖优化指南
如何生成腾讯云建站专用兑换码?
SQL查询语句优化的实用方法总结
如何确保西部建站助手FTP传输的安全性?
如何快速搭建自助建站会员专属系统?
建站之星如何快速解决建站难题?
网站制作和推广的区别,想自己建立一个网站做推广,有什么快捷方法马上做好一个网站?
建站主机服务器选型指南与性能优化方案解析
如何高效利用200m空间完成建站?
如何确认建站备案号应放置的具体位置?
如何高效配置香港服务器实现快速建站?
建站之星如何一键生成手机站?
想学网站制作怎么学,建立一个网站要花费多少?
临沂网站制作企业,临沂第三中学官方网站?
如何在橙子建站中快速调整背景颜色?
如何通过服务器快速搭建网站?完整步骤解析
制作网站的基本流程,设计网站的软件是什么?
保定网站制作方案定制,保定招聘的渠道有哪些?找工作的人一般都去哪里看招聘信息?
建站中国必看指南:CMS建站系统+手机网站搭建核心技巧解析
网站代码制作软件有哪些,如何生成自己网站的代码?
英语简历制作免费网站推荐,如何将简历翻译成英文?
如何快速辨别茅台真假?关键步骤解析
如何用PHP快速搭建CMS系统?
h5在线制作网站电脑版下载,h5网页制作软件?
建站主机系统SEO优化与智能配置核心关键词操作指南
Avalonia如何实现跨窗口通信 Avalonia窗口间数据传递
,网页ppt怎么弄成自己的ppt?
c# 服务器GC和工作站GC的区别和设置
网站制作软件有哪些,制图软件有哪些?
较简单的网站制作软件有哪些,手机版网页制作用什么软件?
建站主机解析:虚拟主机配置与服务器选择指南
,有什么在线背英语单词效率比较高的网站?
*请认真填写需求信息,我们会在24小时内与您取得联系。