首页 / 脚本样式 / Ajax / Ajax在不同浏览器中的兼容问题(asp.net,ie,firefox)
Ajax在不同浏览器中的兼容问题(asp.net,ie,firefox)2011-08-23 cnblogs zhaotiantangAjax在不同浏览器中的兼容问题比较麻烦,我在最近的项目中遇到了这个问题。并且使用了一种奇怪 的方法解决了它,现在拿出来大家讨论讨论:下面是前端代码:<script type="text/javascript">
var xmlHttp;
var as;
var state = 0;
function mouseover()
{
var id = "<%=cvE_Mail.ClientID%>";
getajax();
if (as == 0)
{
alert("Your WebBrowser do not support our service,Choose IE7 or FireFox and try again!");
}
else
{
//在回传的时候邦定事件也不同
if (as == 1)
{
xmlHttp.onreadystatechange = myResponseHandler;
}
else
{
xmlHttp.onload = myResponseHandler;
xmlHttp.onerror = myResponseHandler;
}
//在这里open的时候如果方式选为get,很奇怪firefox的处理端收不到传过去的参数
//在这里可以看到最后一个参数也是不同的,如果不这样设置那么返回的responseText 很 有可能是空的
if (as == 1)
{
xmlHttp.open("POST", "ajax.ashx", true);
}
else
{
xmlHttp.open("POST", "ajax.ashx", false);
}
xmlHttp.send(document.getElementById(id).value);
}
};
function getajax()
{
//首先是创建的时候不同
try {
xmlHttp = new ActiveXObject("Microsoft.XMLHTTP");
as = 1;
} catch (e) {
try {
xmlHttp = new ActiveXObject("Msxml2.XMLHTTP");
as = 1;
} catch (e) {
try {
xmlHttp = new XMLHttpRequest();
as = 2;
} catch (e) {
xmlHttp = null;
as = 0;
}
}
}
}
function myResponseHandler()
{
var id = "<%=Hidebutton.ClientID%>";
if (xmlHttp.readyState == 4)
{
document.getElementById(id).value=xmlHttp.responseText;
}
};
</script>