有些事情看起来简单,处理起来才会知道很麻烦。同样在更改页面颜色调节功能 IE 与 Firefox 的兼容性时遇到的几个问题及解决办法供大家参考:
1、Firefox 无法响应 DIV 的 onClick 事件
原因:Firefox 下不支持以下语法:
<DIV onClick="javascript:onPre();">
解决:全部按以下形式书写:
<DIV onClick=onPre()>
2、无法动态创建页面元素,即 createElement 无效
原因:在 Fireox 下不只能使用标签名做参数,不能使用 <> 形式,如以下语句在 Firefox 下不起作用, 但在 IE 下能正常工作:
var obj=document.createElement(‘<DIV id=h_sb></DIV>’);
解决:全部按以下形式书写:
var obj=document.createElement(‘DIV’);
obj.id=’h_sb’;
3、在为动态创建的元素指定事件处理函数时,在 Firefox 下是运行指定函数,而非设置
原因:Firefox 下,指定时间处理函数时不能带参数,否则 Firefox 只会执行函数,如:
obj.onClick=test(1);
在 Firefox 下会运行 test 函数,而不是将 test 函数关联到 obj 的 click 事件
解决:如果指定函数无参数则使用:
obj.onClick=test;
如果指定函数有参数则:
obj.onClick=function(){test(1)};
4、将动态元素添加到页面时,insertBefore 出错
原因:在 Firefox 下不可省略 insertBefore 函数的第二参数
解决:使用如下语句:
document.body.insertBefore(obj,null);
5、Firefox 下无 event 对象,无法直接获取鼠标坐标
解决:在指定事件处理函数时使用如下语句:
obj.onClick=function(ev){onMidClick(ev,sb_h)};
说明:以上 ev 参数类时 ie 的 event 对象,由系统自动填入,第二参数为用户自定义参数
在处理函数 onMidClick 中:
function onMidClick(evt,objSb){
}
6、表格操作函数无效,即以下语句无法工作:
原因:与第四一样不可缺省参数
解决:使用如下语句:
7、Firefox 下无法直接获取 styleSheet 的 cssText,在 IE 下,可直接获取并设置 styleSheet 的 cssText,但在 Firefox 下只能使用 document.styleSheets[0].cssRules[0].cssText 单个获取样式,同时使用使用:
document.styleSheets[0].cssRules[0].cssText=newcssText;
页面不会自动更新样式,必须使用:
document.styleSheets[0].cssRules[0].style.cssText=newcssText;
8、Firefox 下使用数组不能使用圆括号 (),只能使用中括号 []