ajax不使用IE,但与所有其他浏览器配合良好

时间:2013-09-09 16:05:58

标签: javascript

请有人告诉我为什么这段代码适用于IE浏览器的所有浏览器,我似乎无法找到错误,是兼容性问题还是我的代码缺少Microsoft需要的东西,这段代码是为了提交一个表单并从XMLHttpRequest对象获取响应

//defining XHR object

 function createXHR() {
     if (window.XMLHttpRequest) { // code for IE7+, Firefox, Chrome, Opera, Safari
         return new XMLHttpRequest();
     } else { // code for IE6, IE5
         //return new ActiveXObject("Microsoft.XMLHTTP");
         if (window.XMLHttpRequest) {
             return new window.XMLHttpRequest;
         } else {
             try {
                 return new ActiveXObject("MSXML2.XMLHTTP.3.0");
             } catch (ex) {
                 return null;
             }
         }
     }
 }

 //function to make parameter and value pairs

 function encodeNameAndValue(sName, sValue) {
     var sParam = encodeURIComponent(sName);
     sParam += "=";
     sParam += encodeURIComponent(sValue);
     return sParam;
 }

 //function to get the form fields

 function getRequestBody(oForm) {
     //array to hold the params
     var aParams = new Array();
     //get your reference to the form
     var oForm = document.form1;
     //iterate over each element in the form-

     for (var i = 0; i < oForm.elements.length; i++) { //start of for loop to loop through   form elements---
         //get reference to the field
         var oField = oForm.elements[i];
         //different behavior based on the type of field-----------------     switch                                                 statement---------------
         switch (oField.type) {
             //buttons - we don’t care
         case "button":
         case "submit":
         case "reset":
             break;
             //checkboxes/radio buttons - only return the value if the control is
             //checked.
         case "checkbox":
         case "radio":
             if (!oField.checked) {
                 break;
             }
             //text/hidden/password all return the value
         case "text":
         case "hidden":
         case "password":
             aParams.push(encodeNameAndValue(oField.name, oField.value));
             break;
             //everything else
         default:

             switch (oField.tagName.toLowerCase()) {
             case "select":
                 aParams.push(encodeNameAndValue(oField.name,
                     oField.options[oField.selectedIndex].value));
                 break;
             default:
                 aParams.push(encodeNameAndValue(oField.name,
                     oField.value));
             }
         }
     } //end of for loop
     return aParams.join("&");
 }

 //function to make the make asynch request

 function sendRequest() {
     var oForm = document.form1;
     var sBody = getRequestBody(oForm);
     var oXHR = createXHR();
     oXHR.open("post", oForm.action, true);
     oXHR.setRequestHeader("Content-Type", "application/x-www-form-urlencoded");
     oXHR.onreadystatechange = function () {
         if (oXHR.readyState == 4) {
             if (oXHR.status == 200) {
                 //---------------------------------------------------
                 saveResult(oXHR.responseText);
             } else {
                 saveResult("An error occurred: " + oXHR.statusText);
                 //---------------------------------------------------
             }
         }
     };
     oXHR.send(sBody);
 }
 //function to send data to the display div

 function saveResult(sMessage) {
     var divStatus = document.getElementById("divStatus");
     divStatus.innerHTML = "" + sMessage;
 }

1 个答案:

答案 0 :(得分:0)

您必须编写一些特定于8和9的代码

http://msdn.microsoft.com/en-us/library/dd573303%28v=vs.85%29.aspx

如果你想在不改变代码的情况下在你的IE中工作,那么

更改IE设置Internet选项 - &gt;安全性 - &gt;自定义级别 - &gt; Miscellinous - &gt;跨域启用Access数据源

由于Activex对象被阻止,因此会出现此问题。