IE和Firefox浏览器CSS网页布局不同点

2019-03-14 20:15:09于丽

  问题说明:Firefox的body对象在body标签没有被浏览器完全读入之前就存在;而IE的body对象则必须在body标签被浏览器完全读入之后才存在。
  [注]这个问题尚未实际验证,待验证后再来修改。
  [注]经验证,IE6、Opera9以及FireFox2中不存在上述问题,单纯的JS脚本可以访问在脚本之前已经载入的所有对象和元素,即使这个元素还没有载入完成。
十五、事件委托方法
  问题说明:IE下,使用document.body.onload=inject;其中functioninject()在这之前已被实现;在Firefox下,使用document.body.onload=inject();
  解决方法:统一使用document.body.onload=newFunction('inject()');或者document.body.onload=function(){/*这里是代码*/}
  [注意]Function和function的区别
十六、访问的父元素的区别
  问题说明:在IE下,使用obj.parentElement或obj.parentNode访问obj的父结点;在firefox下,使用obj.parentNode访问obj的父结点。
  解决方法:因为firefox与IE都支持DOM,因此统一使用obj.parentNode来访问obj的父结点。
十七、cursor:handVScursor:pointer
  问题说明:firefox不支持hand,但ie支持pointer,两者都是手形指示。
  解决方法:统一使用pointer。
十八、innerText的问题.
  问题说明:innerText在IE中能正常工作,但是innerText在FireFox中却不行。
  解决方法:在非IE浏览器中使用textContent代替innerText。
  示例:
if(navigator.appName.indexOf("Explorer")>-1){
document.getElementById('element').innerText="mytext";
}else{
document.getElementById('element').textContent="mytext";
}
  [注]innerHTML同时被ie、firefox等浏览器支持,其他的,如outerHTML等只被ie支持,最好不用。
十九、对象宽高赋值问题
  问题说明:FireFox中类似obj.style.height=imgObj.height的语句无效。
  解决方法:统一使用obj.style.height=imgObj.height 'px';
二十、Table操作问题
  问题说明:ie、firefox以及其它浏览器对于table标签的操作都各不相同,在ie中不允许对table和tr的innerHTML赋值,使用js增加一个tr时,使用appendChild方法也不管用。
  解决方法:
//向table追加一个空行:
varrow=otable.insertRow(-1);
varcell=document.createElement("td");
cell.innerHTML="";
cell.className="XXXX";
row.appendChild(cell);
  [注]由于俺很少使用JS直接操作表格,这个问题没有遇见过。建议使用JS框架集来操作table,如JQuery。
二一、ul和ol列表缩进问题
  消除ul、ol等列表的缩进时,样式应写成:list-style:none;margin:0px;padding:0px;
  其中margin属性对IE有效,padding属性对FireFox有效。←此句表述有误,详细见↓