作家
登录

如何用ajax来创建一个XMLHttpRequest对象

作者: 来源:www.28hudong.com 2013-03-30 00:18:38 阅读 我要评论

我每次创建一个对象,都要这样复杂吗?如下代码: JScript code: "testAjax.htm" 文件: 复制代码 代码如下: <html>   <body>   <script type="text/javascript">   function ajaxFunction()   {   var xmlHttp;   try   {   // Firefox,Opera 8.0+,Safari   xmlHttp=new XMLHttpRequest();   }   catch (e)   {   // Internet Explorer   try   {   xmlHttp=new ActiveXObject("Msxml2.XMLHTTP");   }   catch (e)   {   try   {   xmlHttp=new ActiveXObject("Microsoft.XMLHTTP");   }   catch (e)   {   alert("您的浏览器不支持AJAX!");   return false;   }   }   }   }   </script>   <form name="myForm">   用户: <input type="text" name="username" />   时间: <input type="text" name="time" />   </form></body>   </html> 首先声明一个保存 XMLHttpRequest 对象的 xmlHttp 变量。 然后使用 XMLHttp=new XMLHttpRequest() 来创建此对象。这条语句针对 Firefox、Opera 以及 Safari 浏览器。假如失败,则尝试针对 Internet Explorer 6.0+ 的 xmlHttp=new ActiveXObject(“Msxml2.XMLHTTP”),假如也不成功,则尝试针对 Internet Explorer 5.5+ 的 xmlHttp=new ActiveXObject(“Microsoft.XMLHTTP”)。假如这三种方法都不起作用,那么这个用户所使用的浏览器已经太过时了,他或她会看到一个声明此浏览器不支持 AJAX 的提示。可以不用这么麻烦,直接可以把这个函数的定义单独保存为一个js文件,在需要使用AJAX的页面中引用这个文件就可以了。 如下面详解的例子: JScript code: 复制代码 代码如下:function CreateHTTPObject() { var xmlhttp; try { xmlhttp = new ActiveXObject("Msxml2.XMLHTTP"); } catch (e) { try { xmlhttp = new ActiveXObject("Microsoft.XMLHTTP"); } catch (e) { xmlhttp = false; } } if (!xmlhttp && typeof XMLHttpRequest!='undefined') { try { xmlhttp = new XMLHttpRequest(); } catch (e) { xmlhttp=false; } } if (!xmlhttp && window.createRequest) { try { xmlhttp = window.createRequest(); } catch (e) { xmlhttp=false; } } return xmlhttp; }定义上面的函数,调用时创建实例即可,如下: JScript code: 复制代码 代码如下: var xmlHttp = CreateHTTPObject(); if (!xmlHttp) { return; //无法创建 xmlhttp 对象 } xmlHttp.open("GET", url, true); xmlHttp.onreadystatechange = function(){HandleRequest(xmlHttp, "元素ID")}; xmlHttp.send(null); 也可以直接用jquery ,一句话搞定,如下代码: 复制代码 代码如下: $(document).ready(function(){ $("#userpass").blur(function(){ var password=$("#userpass").val(); var name=$("#username").val(); if(password==""||password==null){ $("#pass").html("<font color='red'>请输入密码! </font>"); b=false; }else if(!/^[a-zA-Z0-9_]{6,16}$/.test(password)){ $("#pass").html("<font color='red'>输入格式不正确!密码应至少6为数字或字符 </font>"); b=false; }else{ $.get("LoginAjaxPassword",{"userpass":encodeURI(encodeURI(password)),"username":encodeURI(encodeURI(name))},function(response){ $("#pass").html(response); if(response=="<font color='green' size='2' >"+"√"+"</font>"){ b=true; } }); } return b; }); $("#login-submit").click(function(){ var autologin=document.getElementById("autologin").checked; if(a&&b){ //if($("#autologin").attr("checked")==true){ if(autologin==true){ //${"#login-user-form"}.attr("action","AutoLogin"); //$("#login-user-form").submit(); document.form.action="AutoLogin"; document.form.submit(); }else{ //${"#login-user-form"}.attr("action","Login"); //$("#login-user-form").submit(); document.form.action="Login"; document.form.submit(); } } else{} }); }); </script>

  推荐阅读

  javascript向flash swf文件传递参数值注意细节

问题:如何使用javascript向SWF文件传递参数? 在网上找了一个完整的教程,很有启发性和实用性,如下是完整实现的步骤: 配置SwfObject: Swfobject2是目前检测用户是否安装Flash的最佳方法。它被认为是‘行业标准>>>详细阅读


本文标题:如何用ajax来创建一个XMLHttpRequest对象

地址:http://www.17bianji.com/kaifa2/JS/22835.html

关键词: 探索发现

乐购科技部分新闻及文章转载自互联网,供读者交流和学习,若有涉及作者版权等问题请及时与我们联系,以便更正、删除或按规定办理。感谢所有提供资讯的网站,欢迎各类媒体与乐购科技进行文章共享合作。

网友点评
自媒体专栏

评论

热度

精彩导读
栏目ID=71的表不存在(操作类型=0)