javascript实现简单的ajax封装示例
更新时间:2016年12月28日 11:53:25 作者:大前端
这篇文章主要介绍了javascript实现简单的ajax封装功能,结合实例形式分析了ajax基本功能与操作实现技巧,需要的朋友可以参考下
本文实例讲述了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异步封装功能示例
- 原生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封装源码[支持中文]
相关文章
详解小程序BackgroundAudioManager踩坑之旅
这篇文章主要介绍了详解小程序BackgroundAudioManager踩坑之旅,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧2019-12-12关于__defineGetter__ 和__defineSetter__的说明
关于__defineGetter__ 和__defineSetter__的说明...2007-05-05
最新评论