AJax技术

使用原生js写ajax

字号+ 作者:H5之家 来源:H5之家 2017-06-03 11:01 我要评论( )

本文为您介绍使用原生js写ajax的相关介绍,具体代码请看下文// 使用原生js 封装ajax// 兼容xhr对象function createXHR(){ if(typeof XMLHttpRequest != undefine

本文为您介绍使用原生js写ajax的相关介绍,具体代码请看下文

// 使用原生js 封装ajax // 兼容xhr对象 function createXHR(){ if(typeof XMLHttpRequest != "undefined"){ // 非IE6浏览器 return new XMLHttpRequest(); }else if(typeof ActiveXObject != "undefined"){ // IE6浏览器 var version = [ "MSXML2.XMLHttp.6.0", "MSXML2.XMLHttp.3.0", "MSXML2.XMLHttp", ]; for(var i = 0; i < version.length; i++){ try{ return new ActiveXObject(version[i]); }catch(e){ //跳过 } } }else{ throw new Error("您的系统或浏览器不支持XHR对象!"); } } // 转义字符 function params(data){ var arr = []; for(var i in data){ arr.push(encodeURIComponent(i) + "=" + encodeURIComponent(data[i])); } return arr.join("&"); } // 封装ajax function ga_ajax(obj){ var xhr = createXHR(); obj.url = obj.url + "?rand=" + Math.random(); // 清除缓存 obj.data = params(obj.data); // 转义字符串 if(obj.method === "get"){ // 判断使用的是否是get方式发送 obj.url += obj.url.indexOf("?") == "-1" ? "?" + obj.data : "&" + obj.data; } // 异步 if(obj.async === true){ // 异步的时候需要触发onreadystatechange事件 xhr.onreadystatechange = function(){ // 执行完成 if(xhr.readyState == 4){ callBack(); } } } xhr.open(obj.method,obj.url,obj.async); // false是同步 true是异步 // "demo.php?rand="+Math.random()+"&name=ga&ga", if(obj.method === "post"){ xhr.setRequestHeader("Content-Type","application/x-www-form-urlencoded"); xhr.send(obj.data); }else{ xhr.send(null); } // xhr.abort(); // 取消异步请求 // 同步 if(obj.async === false){ callBack(); } // 返回数据 function callBack(){ // 判断是否返回正确 if(xhr.status == 200){ obj.success(xhr.responseText); }else{ obj.Error("获取数据失败,错误代号为:"+xhr.status+"错误信息为:"+xhr.statusText); } } } var html = document.getElementsByTagName("html")[0]; html.onclick = function(){ ga_ajax({ "method" : "post", "url" : "demo.php", "data" : { "name" : "gao", "age" : 100, "num" : "12346&598" }, "success" : function(data){ alert(data); }, "Error" : function(text){ alert(text); }, "async" : false }); }

谢谢您的访问.

这些内容可能对你也有帮助

更多PHP教程可查看PHP教程列表页。

 

1.本站遵循行业规范,任何转载的稿件都会明确标注作者和来源;2.本站的原创文章,请转载时务必注明文章作者和来源,不尊重原创的行为我们将追究责任;3.作者投稿可能会经我们编辑修改或补充。

相关文章
  • 《电脑编程技巧与维护》2010年11期

    《电脑编程技巧与维护》2010年11期

    2017-06-03 12:03

  • 基于Ajax技术的Web页面开发.doc

    基于Ajax技术的Web页面开发.doc

    2017-06-03 08:00

  • AJAX技术及其在教育装备统计系统中的应用

    AJAX技术及其在教育装备统计系统中的应用

    2017-06-02 16:02

  • ajax Post之后的页面跳转问题

    ajax Post之后的页面跳转问题

    2017-06-02 16:01

网友点评