javascript实现简单的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程序设计有所帮助。
相关推荐
chongxiaocheng 2020-08-16
ppsurcao 2020-06-14
kentrl 2020-11-10
结束数据方法的参数,该如何定义?-- 集合为自定义实体类中的结合属性,有几个实体类,改变下标就行了。<input id="add" type="button" value="新增visitor&quo
ajaxyan 2020-11-09
zndy0 2020-11-03
学留痕 2020-09-20
learningever 2020-09-19
ajaxhe 2020-08-16
lyqdanang 2020-08-16
curiousL 2020-08-03
时光如瑾雨微凉 2020-07-19
坚持着执着 2020-07-16
jiaguoquan00 2020-07-07
李永毅 2020-07-05