1200字范文,内容丰富有趣,写作的好帮手!
1200字范文 > 几个IE与Firefox的兼容性问题 (一 网络转载)

几个IE与Firefox的兼容性问题 (一 网络转载)

时间:2018-10-03 12:37:32

相关推荐

几个IE与Firefox的兼容性问题 (一 网络转载)

有些事情看起来简单,处理起来才会知道很麻烦。同样在更改页面颜色调节功能IE与Firefox的兼容性时遇到的几个问题及解决办法供大家参考:

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

原因:Firefox下不支持以下语法:

Javascript代码 <DIVonClick="javascript:onPre();">

<DIV onClick="javascript:onPre();">

解决:全部按以下形式书写:

Javascript代码 <DIVonClick=onPre()>

<DIV onClick=onPre()>

2、无法动态创建页面元素,即createElement无效

原因:在Fireox下不只能使用标签名做参数,不能使用<>形式,如以下语句在Firefox下不起作用,但在IE下能正常工作:

Javascript代码 varobj=document.createElement('<DIVid=h_sb></DIV>');

var obj=document.createElement('<DIV id=h_sb></DIV>');

解决:全部按以下形式书写:

Javascript代码 varobj=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代码 functiononMidClick(evt,objSb){ varmx;//获取鼠标的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代码 varnewrow=objnt.insertRow(); varcal=newrow.insertCell();

var newrow=objnt.insertRow(); var cal=newrow.insertCell();

原因:与第四一样不可缺省参数

解决:使用如下语句:

Javascript代码 varnewrow=objnt.insertRow(-1); varcal=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下使用数组不能使用圆括号(),只能使用中括号[]

本内容不代表本网观点和政治立场,如有侵犯你的权益请联系我们处理。
网友评论
网友评论仅供其表达个人看法,并不表明网站立场。