当前位置: 首页 > 图文教程 > 网页制作 > CSS样式表 > IE和Firefox浏览器CSS网页布局不同点

CSS样式表
css 块状元素和内联元素
CSS 盒模型、块状元素与内联元素、CSS选择器
css 浮动 理解Float的含义
CSS 清除浮动Clear
CSS 制作网页导航条(上)
CSS 制作网页导航条(下)
css 浮动(float)页面布局
css 浮动(float)页面布局(下)
css position 定位
css 定位应用实例
CSS Hack 有关浏览器兼容方面
css 单图片按钮实例(css 图片变换)
使用X-UA-Compatible来设置IE浏览器兼容模式
div overflow 超出隐藏属性使用说明
CSS 使用规则总结
div+CSS 兼容小摘
CSS的inherit与auto使用分析
如何组织和注释CSS文件
CSS样式按整洁易懂的结构组织
CSS Prism 查看和编辑CSS中用到的颜色

CSS样式表 中的 IE和Firefox浏览器CSS网页布局不同点


出处:互联网   整理: 软晨网(RuanChen.com)   发布: 2009-09-11   浏览: 148 ::
收藏到网摘: n/a


                         我们讨论的主题CSS网页布局,最令大家头疼的问题就是浏览器兼容性,虽然ruanchen.com介绍过很多这方向的知识,但依然让很多开发人员晕头转向,今天的这篇文章,将列出css和javascript在IE和Firefox中二十三个不同点,希望对大家的学习有所帮助。                我们讨论的主题CSS网页布局,最令大家头疼的问题就是浏览器兼容性,虽然ruanchen.com介绍过很多这方向的知识,但依然让很多开发人员晕头转向,今天的这篇文章,将列出css和javascript在IE和Firefox中二十三个不同点,希望对大家的学习有所帮助。
一、document.formName.item("itemName")问题
  问题说明:IE下,可以使用document.formName.item("itemName")或document.formName.elements["elementName"];Firefox下,只能使用document.formName.elements["elementName"]。
  解决方法:统一使用document.formName.elements["elementName"]。
二、集合类对象问题
  问题说明:IE下,可以使用()或[]获取集合类对象;Firefox下,只能使用[]获取集合类对象。
解决方法:统一使用[]获取集合类对象。
三、自定义属性问题
  问题说明:IE下,可以使用获取常规属性的方法来获取自定义属性,也可以使用getAttribute()获取自定义属性;Firefox下,只能使用getAttribute()获取自定义属性。
  解决方法:统一通过getAttribute()获取自定义属性。
四、eval("idName")问题
  问题说明:IE下,可以使用eval("idName")或getElementById("idName")来取得id为idName的HTML对象;Firefox下,只能使用getElementById("idName")来取得id为idName的HTML对象。
  解决方法:统一用getElementById("idName")来取得id为idName的HTML对象。
五、变量名与某HTML对象ID相同的问题
  问题说明:IE下,HTML对象的ID可以作为document的下属对象变量名直接使用,Firefox下则不能;Firefox下,可以使用与HTML对象ID相同的变量名,IE下则不能。
  解决方法:使用document.getElementById("idName")代替document.idName。最好不要取HTML对象ID相同的变量名,以减少错误;在声明变量时,一律加上var关键字,以避免歧义。
六、const问题
  问题说明:Firefox下,可以使用const关键字或var关键字来定义常量;IE下,只能使用var关键字来定义常量。
  解决方法:统一使用var关键字来定义常量。
七、input.type属性问题
  问题说明:IE下input.type属性为只读;但是Firefox下input.type属性为读写。
  解决办法:不修改input.type属性。如果必须要修改,可以先隐藏原来的input,然后在同样的位置再插入一个新的input元素。
八、window.event问题
  问题说明:window.event只能在IE下运行,而不能在Firefox下运行,这是因为Firefox的event只能在事件发生的现场使用。
  解决方法:在事件发生的函数上加上event参数,在函数体内(假设形参为evt)使用varmyEvent=evt?evt:(window.event?window.event:null)
示例:
<inputtype="button"onclick="doSomething(event)"/>
<scriptlanguage="javascript">
functiondoSomething(evt){
varmyEvent=evt?evt:(window.event?window.event:null)
...
}
九、event.x与event.y问题
  问题说明:IE下,even对象有x、y属性,但是没有pageX、pageY属性;Firefox下,even对象有pageX、pageY属性,但是没有x、y属性。
  解决方法:varmyX=event.x?event.x:event.pageX;varmyY=event.y?event.y:event.pageY;
  如果考虑第8条问题,就改用myEvent代替event即可。
十、event.srcElement问题
  问题说明:IE下,even对象有srcElement属性,但是没有target属性;Firefox下,even对象有target属性,但是没有srcElement属性。
  解决方法:使用srcObj=event.srcElement?event.srcElement:event.target;
  如果考虑第8条问题,就改用myEvent代替event即可。
十一、window.location.href问题
  问题说明:IE或者Firefox2.0.x下,可以使用window.location或window.location.href;Firefox1.5.x下,只能使用window.location。
  解决方法:使用window.location来代替window.location.href。当然也可以考虑使用location.replace()方法。
十二、模态和非模态窗口问题
  问题说明:IE下,可以通过showModalDialog和showModelessDialog打开模态和非模态窗口;Firefox下则不能。
  解决方法:直接使用window.open(pageURL,name,parameters)方式打开新窗口。
  如果需要将子窗口中的参数传递回父窗口,可以在子窗口中使用window.opener来访问父窗口。如果需要父窗口控制子窗口的话,使用varsubWindow=window.open(pageURL,name,parameters);来获得新开的窗口对象。
十三、frame和iframe问题
  以下面的frame为例:
  <framesrc="http://www.ruanchen.com/'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有效。←此句表述有误,详细见↓
  [注]这个问题尚未实际验证,待验证后再来修改。
  [注]经验证,在IE中,设置margin:0px可以去除列表的上下左右缩进、空白以及列表编号或圆点,设置padding对样式没有影响;在Firefox中,设置margin:0px仅仅可以去除上下的空白,设置padding:0px后仅仅可以去掉左右缩进,还必须设置list-style:none才能去除列表编号或圆点。也就是说,在IE中仅仅设置margin:0px即可达到最终效果,而在Firefox中必须同时设置margin:0px、padding:0px以及list-style:none三项才能达到最终效果。
二二、CSS透明问题
  IE:filter:progid:DXImageTransform.Microsoft.Alpha(style=0,opacity=60)。
  FF:opacity:0.6。
  [注]最好两个都写,并将opacity属性放在下面。
二三、CSS圆角问题
  IE:ie7以下版本不支持圆角。
  FF:-moz-border-radius:4px,或者-moz-border-radius-topleft:4px;-moz-border-radius-topright:4px;-moz-border-radius-bottomleft:4px;-moz-border-radius-bottomright:4px;。
  [注]圆角问题是CSS中的经典问题,建议使用JQuery框架集来设置圆角,让这些复杂的问题留给别人去想吧。
  关于CSS中的问题实在太多了,甚至同样的CSS定义在不同的页面标准中的显示效果都是不一样的。更多的知识请参考ruanchen.com的文章。一个合乎发展的建议是,页面采用标准DHTML标准编写,较少使用table,CSS定义尽量依照标准DOM,同时兼顾IE、Firefox、Opera等主流浏览器。BTW,很多情况下,FF和Opera的CSS解释标准更贴近CSS标准,也更具有规范性。