IE与Firefox的几个javascript兼容问题及解决

项目中遇到的问题
  javascript动态创建页面元素
  代码:
  var hName=document.createElement("<input type='hidden' name='midNames'>");
  ie下能正常执行,Firefox下执行不了
解决办法:
   var h = document.createElement('input');
       h.setAttribute('type', 'hidden');

       h.setAttribute('name', 'midNames');

以下为网络收集整理如下:

1、Firefox无法响应DIV的onClick事件

原因:Firefox下不支持以下语法:
  Javascript代码
  <DIV onClick="javascript:onPre();">   
  <DIV onClick="javascript:onPre();">
  解决:全部按以下形式书写:
  Javascript代码
  <DIV onClick=onPre()>   
  <DIV onClick=onPre()>

2、无法动态创建页面元素,即createElement无效
原因:在Fireox下不只能使用标签名做参数,不能使用<>形式,如以下语句在Firefox下不起作用,但在IE下能正常工作:
  Javascript代码
  var obj=document.createElement('<DIV id=h_sb></DIV>');   
  var obj=document.createElement('<DIV id=h_sb></DIV>');
解决:全部按以下形式书写:
  Javascript代码
  var obj=document.createElement('DIV');   
  obj.id='h_sb';   
  var obj=document.createElement('DIV'); obj.id='h_sb';

3、在为动态创建的元素指定事件处理函数时,在Firefox下是运行指定函数,而非设置
原因:Firefox下,指定时间处理函数时不能带参数,否则Firefox只会执行函数,如:
  Javascript代码
  obj.onClick=test(1);   
  obj.onClick=test(1);
在Firefox下会运行test函数,而不是将test函数关联到obj的click事件
  解决:如果指定函数无参数则使用:
  Javascript代码
  obj.onClick=test;   
  obj.onClick=test;
  如果指定函数有参数则:
  Javascript代码
  obj.onClick=function(){test(1)};   
  obj.onClick=function(){test(1)};

4、将动态元素添加到页面时,insertBefore出错
原因:在Firefox下不可省略insertBefore函数的第二参数
  解决:使用如下语句:
  Javascript代码
  document.body.insertBefore(obj,null);   
  document.body.insertBefore(obj,null);

5、Firefox下无event对象,无法直接获取鼠标坐标
解决:在指定事件处理函数时使用如下语句:
  Javascript代码
  obj.onClick=function(ev){onMidClick(ev,sb_h)};   
  obj.onClick=function(ev){onMidClick(ev,sb_h)};
  说明:以上ev参数类时ie的event对象,由系统自动填入,第二参数为用户自定义参数
  在处理函数onMidClick中:
  Javascript代码
    function onMidClick(evt,objSb){   
     var mx;     //获取鼠标的X坐标   
     if ( window.event ){   
      mx=event.clientX;   
     }else{   
      mx=evt.pageX;   
     }   
    }   
    function onMidClick(evt,objSb){ var mx; //获取鼠标的X坐标 if ( window.event )
    { mx=event.clientX; }else{ mx=evt.pageX; } }

6、表格操作函数无效,即以下语句无法工作:
   Javascript代码
   var newrow=objnt.insertRow();   
   var cal=newrow.insertCell();   
   var newrow=objnt.insertRow(); var cal=newrow.insertCell();
   原因:与第四一样不可缺省参数
   解决:使用如下语句:
   Javascript代码
   var newrow=objnt.insertRow(-1);   
   var cal=newrow.insertCell(-1);   
   var newrow=objnt.insertRow(-1); var cal=newrow.insertCell(-1);

7、Firefox下无法直接获取styleSheet的cssText,在IE下,可直接获取并设置styleSheet的cssText,
但在Firefox下只能使用document.styleSheets[0].cssRules[0].cssText单个获取样式,同时使用使用:
   Javascript代码
   document.styleSheets[0].cssRules[0].cssText=newcssText;   
   document.styleSheets[0].cssRules[0].cssText=newcssText;
   页面不会自动更新样式,必须使用:
   Javascript代码
   document.styleSheets[0].cssRules[0].style.cssText=newcssText;   
   document.styleSheets[0].cssRules[0].style.cssText=newcssText;

8、Firefox下使用数组不能使用圆括号(),只能使用中括号[]

你可能感兴趣的:(JavaScript)