IE8的项目在IE11下 一些功能没法实现的解决方案

最近改了一些IE11下一些功能没法实现的项目,发现了有一些IE8下的方法 ,在IE11下被取消或者替代了,以下:ios

1.JavaScript 运行时错误: 对象不支持“attachEvent”属性或方法;浏览器

attachEvent 这个方法在IE11下改为了addEventListener ,因此我这里加了浏览器版本判断 才得以实现了IE8 和IE11下都好用app

 if (navigator.appName == "Microsoft Internet Explorer" && (navigator.appVersion.match(/8./i) == "8." || navigator.userAgent.indexOf("MSIE 8.0") > 0 || navigator.appVersion.match(/7./i) == "7.")) {
                 window.attachEvent("onload", OverrideBaseFunction);
      } else {
                 window.addEventListener("onload", OverrideBaseFunction);
     }ide

2.没法获取未定义或 null 引用的属性“tags”this

   由于这里引用了Jquery,可是在下面没有用到spa

   源代码: var radios=document.body.all.tags("INPUT"); 对象

                 for(var i=0;i<radios.length;i++)
                    {
           if(radios[i].type=="radio")
                {
          if(radios[i].checked)
              {
            type=radios[i].value;
                          break;
           }
        }
   }
ip

改为:get

         type =$('input:radio[name*="type"]:checked').val();    由于引用的是Jquery可是没有使用到,所用用Jquery写一句话input

          var inputs=document.getElementById("cblProcess").all.tags("INPUT");
           var isOne=false;
            for(var i=0;i<inputs.length;i++)
            {
            if(inputs[i].type=="checkbox"&&inputs[i].checked)
             {
             isOne=true;
           break;
            }
         }

3.JavaScript 运行时错误: 没法获取未定义或 null 引用的属性“tags”

             源代码: var tds=tr.all.tags("TD");

                         var result="";
                     for(var i=0;i<tds.length;i++)
                          {
                       var tdText=tds[i].innerText;
                             if(i>0)
                         result+=";"+tdText;
                            else
                       result+=tdText;
                     }

 

      

              改为:var result ="";                      $(tr).each(function(){                       $(this).children("TD").text(function(i,text){                         if(i>0 && text !="")                           {                         return ";" + text;                            }                        });                   result = $(this).children("TD").text();                     $(this).children("TD").text(function(i,text){                    if(i>0 && text !="")                  {                return text.substr(1);                 }             });       });

相关文章
相关标签/搜索