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; } };