读书人

历次用Ajax都需要这么复杂吗

发布时间: 2012-09-25 09:55:58 作者: rapoo

每次用Ajax,都需要这么复杂吗?
我每次创建一个对象,都要这样复杂吗?

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>
[解决办法]
将都会用到的提取出来 独立的放在js中,再去引用就可以了
[解决办法]
可以将ajax封装起来,每次调用就很方便了,楼主 搜下 ajax类
[解决办法]
$.get
$.post
$.ajax jquery多方便
[解决办法]
代码重用
[解决办法]
把创建XMLHttpRequest的函数独立到一个js文件中,每次通过调用来创建新对象。

读书人网 >Ajax

热点推荐