- A+
所属分类:Web前端
最近被大佬问了一个很有趣的问题,你还能手打出一个ajax吗?,我当时的想法是有现成的为什么要自己打,后来我反思了一下(只有靠自己才是强者),在这里给大家分享一个我自己打的ajax,也是自己的一个知识点的记录。
//后台交互ajax方法 //参数1 集合 代表和后台交互的所有数据 function ajax(obj) { obj.type = obj.type || "get"; //指定提交方式的默认值 obj.data = obj.data || null; //设置数据的默认值 var xhr = window.XMLHttpRequest ? new XMLHttpRequest() : new ActiveXObject("Microsoft.XMLHTTP"); // 创建XMLHttpRequest对象 var callback = function (xhr) { if (xhr.readyState == 4) {//判断状态码为4时,表示请求完毕可执行内容。 if (xhr.status >= 200 && xhr.status < 300 || xhr.status == 304) {//如果状态值为200在300之间,或者是读取缓存中的内容成功时,执行内容。 //这里必须要try catch。即使这里mysql报错,也不会影响到程序的使用。 try { obj.success && obj.success(eval(xhr.responseText)); } catch (e) {//如果错误,把错误输出到控制台。 console.log(xhr.responseText); } } else {//如果状态值不是200到300之间,或者不是304表示请求失败,执行失败的内容。 obj.error && obj.error(); } } } var toData = function (obj) { //格式化参数 if (obj == null) { return obj; } var arr = []; for (var i in obj) { var str = i + "=" + obj[i]; arr.push(str); } return arr.join("&"); } if (obj.type == "post") {//判断是get还是post请求 xhr.open(obj.type, obj.url, obj.async);//打开连接,参数是:请求方式、请求地址、是否异步 xhr.setRequestHeader("Content-Type", "application/x-www-form-urlencoded");//如果是post请求,设置请求头信息。设置表单提交时的内容类型 var data = toData(obj.data);//格式化参数 xhr.send(data);//发送请求 obj.async == false && callback(xhr); } else{ //get test.php?xx=xx&aa=xx var url = obj.url + "?" + toData(obj.data);//格式化yrl参数 xhr.open(obj.type, url, obj.async);//打开链接 xhr.send();//发送请求,因为是get请求,所以send()不填参数 } xhr.onreadystatechange = function () {//每次状态改变时执行的函数 callback(xhr); } }