`
liguocai2009
  • 浏览: 31963 次
  • 性别: Icon_minigender_1
  • 来自: 广州
社区版块
存档分类
最新评论

Javascript的IE和Firefox(火狐)兼容性 css

 
阅读更多

FIREFOX与IE兼容性探讨

1. CSS样式兼容性问题的出现

关 于FireFox和IE6对CSS样式的兼容性差异由来已久,它们对标准兼容的差异性,导致了大量网站开发人员的工作量加倍,不得已煞费苦心的在 Firefox和IE间进行调试,对于以前很少有关注过CSS样式浏览器兼容性问题的开发人员来说,更是一件雪上加霜的事情,原本调CSS就是一件很烦的 事情,再加上兼容性问题的阻碍,使很多开发人员咬牙切齿,却也无可奈何。

2. CSS样式调试工具

有 句话说得好,工欲善其事,必先利其器。作为一名IT开发人员来说那就是欲想编程好,必先工具好。在C++方面有Microsoft Studio的支持,在Java方面有eclipse的支持,而对于市面上调试CSS样式的工具却不是很多,但现有的工具也基本上满足我们的需求。首先介 绍FireFox下的调试工具Firebug,这一款非常优秀的调试工具,不仅对CSS样式的调试起了所见即所得的功效,同时还支持JS的调试,DOM查 看器,控制台,可编辑Html及网络状况监视器等(JS等方面请查看其他相关文档)。对于开发人员来说,有如此好的调试工具,当然是不容错过的一件事情。 IE6下也提供了一款CSS样式调试工具IE DevToolbar,这款工具相对来说功能相对单一,但为了在IE上也能够进行CSS进行调试,这款工具也勉强派得上用场了。 由于对标准支持的不统一,IE对浏览器领域统治多年,产生了自己的一套标准,而兴起的Firefox及Google的Chrome则是对原有的标准进行了 支持,所以两者之间的冲突在所难免。现在以实例方式来说明两种浏览器之间的差异,并提供相应的解决方法。希望在浏览器CSS样式兼容性上有需要的朋友可以 得到帮助。

3. Firefox与IE的Hack介绍

Hack 是指浏览器对CSS样式某些标志的识别,通过这些识别,同一CSS属性我们可以为不同的浏览器指定不同的CSS样式,以规避浏览器不同带来的差异。 首先介绍“!important”,这是我们最常使用的Hack标识,记住,需要“!”作为开头,比如“width:80!important;”。这是 一个IE7和Firefox都能够识别的标志,加上这个标志等于相同的CSS属性上,IE7或者Firefox会优先读取这个属性,所以当需要区别IE6 和Firefox样式时可以使个标志。这也是最常用的Hack,因为IE7和Firefox支持的CSS样式标准基本一样,所以对CSS样式的兼容也基本 上相同。 其次是介绍“*”,这是一个IE能够识别的标签,而Firefox无法识别的标签,在Firefox上忽略由该标志指定的CSS样式。所以当需要区别 IE7和Firefox时可以使用如:“*width:80!important”,这也是IE6无法识别的标签。

Table 1. IE6,IE7,Firefox的对于Hack标志区别

  IE6 IE7 FireFox
* Y Y N
!important N Y Y
_ Y N N

通过这个表格,我们找到了一种同时区别三种浏览器对CSS支持的方法: 如“width:80px;*width:60px;_width:100px;” 希望这个好的建议可以给大学解决浏览器间的CSS样式差异提供帮助。

4. CSS样式兼容性问题分类

总 结来说CSS样式兼容性问题总共有三大类: 第一类为大小显示不一致:如margin-left或者height双倍显示,空格显示等; 第二类为位置显示不一致:如div居中显示,td默认内容位置等; 第三类则比较零散,需要在特定的场景才会出现,而特定的场景往往比较复杂,所以这里只给出建议,当遇到类似问题时,不妨参考一下解决方法,以找到正确设置 CSS样式一致的方案。 现举例,一一说明问题的由来,并提供重现代码,以供读者更清晰的了解导致问题的原因,以找到更好的解决方案,其中margin-left双倍显 示,table、form、div自适应,table的padding,width和height的计算是经常遇到的问题。

5. CSS兼容性案例分析及解决方案

现在就CSS这三类在项目中遇到的问题进行重现,并提出相应的解决方案。

5.1. margin-left双倍显示

margin-left在IE下双倍显示是IE裡面的一个bug,在很多种情况下会出现这种情况。现在列举一种最常见的是在两个都是float:left的Div旁,那么margin-left在IE里显示的就是两倍的。

<div style="border:1px solid #cccccc;width:600px;height:500px;float:left;">    <div style="border:1px solid #00cccc;width:100px;height:100px;float:left;margin-left:50px;">    </div></div>

解 决方法: 通过CSS的Hack标志加上“!important”来标识Firefox读取这个属性值优先,而IE6不认识这个标识,所以FireFox读取的属性 是“margin-left:50px;”,而IE6则读取“margin-left:25px”,当IE6的margin-left显示双倍时,就得到 了50px,从而避开IE6的这个bug,达到两个浏览器的CSS样式兼容。(在后面的例子中,解决方法也基本类似,主要是把关键代码标上特殊颜色,供读 者参考)。

<div style="border:1px solid #cccccc;width:600px;height:500px;float:left;">    <div style="border:1px solid #00cccc;width:100px;height:100px;float:left;margin-left:50px!important;margin-left:25px;">    </div></div>

5.2. table、form、div自适应

在 firefox里面,form里面的内容超出form的容量时也不会自动扩展form、table及div的内容,而在IE里,table、form或者 div里面的内容超出宽度时,则自动扩展外层的table、form及div,所以当我们从firefox上切换到IE6时这个问出现得比较多。

<table style="height:100px;width: 80px;border:1px solid #00FF00">    <tr><td>        <form style="border:1px solid #CCCCCC;width:80px;height:80px;">            <input type="text"/>        </form>    </td></tr></table>

解决办法: (1).固定外层table、form或者div的宽度或者高度适应内层的内容

<table style="height:100px;width:180px;border:1px solid #00FF00">    <tr><td>        <form style="border:1px solid #CCCCCC;width:170px;height:80px;">            <input type="text"/>        </form>    </td></tr></table>

(2).缩小里面的内容,小于table、form或者是div的宽度或者高度

<table style="height:100px;width: 80px;border:1px solid #00FF00">    <tr><td>        <form style="border:1px solid #CCCCCC;width:80px;height:80px;">            <input type="text" style="width:60px"/>        </form>    </td></tr></table>

5.3. IE里div下的img默认有空格

这个问题是当初在设计导航条时遇到的问题,导航条很多时候就是横向一排div,每个div里面都是图片,就会在IE下产生了多了一点小空格的问题。

<div style="border:1px solid #FF0000;height:132px;width:100px;">    <img src="img/om.gif"/></div>

解决办法: (1)、将div下的font-size设置为0

<div style="border:1px solid #FF0000;height:132px;width:100px;font-size:0px">    <img src="img/om.gif"/></div>

(2)、整合div里面的内容,使其没有空格,这样也可以使内容紧凑,这里可以看IE里面没有忽略img旁边的空格导致的问题

<div style="border:1px solid #FF0000;height:132px;width:100px; "><img src="img/om.gif"/></div>

5.4. 空格大小

默认字本显示问题,导致&nbsp;显示的大小不一致,当你使用了&nbsp;造成问题时请注意。

<table>    <tr>        <td>中华人民共&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;和国</td>    </tr></table>

5.5. IE里div里默认line-height

在IE里Div设置至少有一个line-height所以显示的时候IE下的div显示无法显示等于10px。

<div style="margin-left: 15px; border: 1px solid #FF0000; width: 60px; height: 40px;">    <div style="margin-left: 15px; border: 1px solid #FF0000; width: 20px; height: 10px;">    </div></div>

解决方法: 设置div层里的字体大小为0,则div的高度可以自由设置。

<div style="margin-left: 15px; border: 1px solid #FF0000; width: 60px; height: 40px;">    <div style="margin-left: 15px; border: 1px solid #FF0000; width: 20px;height:10px;font-size:0px;">    </div></div>

5.6. div居中center

当设置了“margin-left:auto;margin-right:auto”后,Firefox里的可以居中显示div,而IE上则不可以显示居中。

<div style="width:400px;height:80px;border:1px solid #FE871A;margin-left:auto;margin-right:auto;">    测试div上内容显示的位置</div>

这个问题我尚未有解决办法,所以,在使用div居中时,请注意这个问题,或者可以考虑使用table替换,不要被div居中困扰,希望能对你有帮助。

5.7. table的padding

这个问题也是我们经常遇到的问题,因为在firefox下,table的padding实在是太好用了,当我们转到IE6上时才发现,要改过来的痛苦,所以在使用table的padding时请注意兼容问题。

<table style="width:300px;height:100px;border:8px solid #CCCCCC;padding:18px;">    <tr>        <td  style="border:1px solid #ff0000">测试Table的padding</td>    </tr></table>

解决办法: 建议在td里面使用一个div,然后设置div的margin,使其出现在td正确的位置上。

<table style="width:300px;height:100px;border:8px solid #CCCCCC;">    <tr><td>        <div style="border:1px solid #ff0000;width:200px;height:50px;margin-left:8px;">测试Table的padding</div>    </td></tr></table>

5.8. tr和td的border

先 声明,这个问题的发现是在我的实际项目中遇到的,项目中是想显示一条横线,但是目前我无法重现出来,所以如果大家有遇到类似问题的时候可以参考一下。在 Firefox下,显示的td的border-top的时候可以显示,而在IE6下则无法显示的问题,总结了一下是td显示边框的时候会出现的问题。所以 解决办法是在td里面再设置一个div来进行显示。

<table>   <tr><td style="width:300px;height:1px;border-top:1px solid #ff0000">   </td></tr></table>

解决办法:

<table>    <tr><td>       <div style="width:300px;height:1px;border-top:1px solid #ff0000"></div>    </td></tr></table>

5.9. width和height的计算

这 个问题应该是大部分人都会遇到的了,先介绍一下Firefox和IE下计算width和height的方法: 在IE下: 显示宽度=marginLeft + width + marginRight; 显示高度=marginTop + height +marginBottom; 在Firefox下: 显示宽度=marginLeft + paddingLeft + borderLeft + width + marginRight + paddingRight + borderRight; 显示高度=marginTop + padingTop + borderTop + height + marginBottom + paddingBottom + borderBottom;

<div>    <div style="width:280px;margin-left:40px;padding-left:15px;border-width: 1px 20px 1px 20px;border-style: solid;border-color:#FE871A">       测试width    </div>    <br/>    <div style="height:100px;width:200px;margin-top:40px;padding-top:15px;border-width:20px 1px 20px 1px;border-style:solid;border-color:#CCCCCC;">        测试height    </div></div>

解决办法: 看到上面的示例后,可以选择用Hack来解决兼容性问题,

<div>    <div style="width:225px!important;width:280px;margin-left:40px;padding-left:15px;border-width:1px 20px 1px 20px;border-style: solid;border-color:#FE871A">        测试width    </div>    <br/>    <div style="height:45px!important;height:100px;width:200px;margin-top:40px;padding-top:15px;border-width:20px 1px 20px 1px; border-style:solid;border-color:#CCCCCC;">        测试height    </div></div>

5.10. 链接a里面div

在firefox链接里面放一个div是在点击链接时候会莫名其妙的出现两个点(在firefox3下显示得很明显),而在IE里则显示多下横线,鼠标移过时显示的图标不一致:

<table><tr><td>    <a href="#" _fcksavedurl="#"> _fcksavedurl="#"> _fcksavedurl="#">        <div style="border: 1px #cccccc solid;height:30px;width:80px;">本地链接</div>    </a></td></tr></table>

解决办法: 在显示链接的时候设置cursor:pointer和text-decoration:underline;或者设置其他值,解决两个点的问题当然是把链接移动外面显示才是最好的解决方式,但由于特殊需要div必须放在链接里面时,目前不没有有效的解决方式。

<style type="text/css">a:hover{    cursor:pointer;}div{    text-decoration:underline;}</style>

5.11. cursor不一致

在IE中cursor:hand和cursor:pointer都显示手形,而Firefox中,cursor:hand则显示为编辑图标,只是把它当文字处理而已,若要在Firefox中显示手形,请设置cursor:pointer。

<span style="cursor:hand;">hand</span><span style="cursor:pointer;">pointer</span>

6. 总结

在CSS兼容道路上,相信前景还是很美好的,毕竟我们Microsoft在IE7和IE8支持标准的程度已经大大提高,现在写的这篇文章里只是略微阐述了对CSS兼容性的一些实践看法,希望对大家有所帮助,也希望大家提供更多的建议给我,使得本文的阐述更完善。

 

本文 转自:http://www.operamasks.org/article/static/ART00084.html#d0e9

 

分享到:
评论

相关推荐

    Javascript的IE和Firefox(火狐)兼容性

    ### Javascript的IE与Firefox(火狐)兼容性解决方案 在Web开发过程中,浏览器兼容性问题一直是开发者们关注的重点之一。由于不同的浏览器对于Web标准的支持程度存在差异,这导致了同样的代码在不同浏览器中的表现...

    Javascript的IE和Firefox兼容性问题集合

    以下是一些常见的JavaScript在IE和Firefox上的兼容性问题及其解决策略: 1. **事件处理**:IE使用attachEvent方法添加事件监听器,而Firefox则使用addEventListener。为确保兼容,可以创建一个跨浏览器的事件处理...

    IE与Firefox的CSS兼容大全.rar

    "IE与Firefox的CSS兼容大全"是一个针对这两个浏览器之间CSS兼容性问题的资源集合,旨在帮助网页开发者解决在跨浏览器设计时遇到的难题。 首先,IE浏览器,尤其是早期版本,如6、7和8,对于CSS标准的支持并不完全。...

    DOM文档和Javascript的IE和Firefox兼容性

    "Javascript的IE和Firefox兼容性"则涉及到JavaScript在不同浏览器中的行为一致性问题。Internet Explorer(IE)和Mozilla Firefox是两个历史悠久且具有广泛用户基础的浏览器,它们对JavaScript的支持存在差异,尤其...

    IE和Firefox在css,JavaScript方面的兼容性

    标题与描述均聚焦于“IE和Firefox在css,JavaScript方面的兼容性”,这涉及到网页开发中一个重要的议题:浏览器兼容性。在web开发中,确保代码能在不同浏览器上正常运行是至关重要的,因为用户可能使用各种不同的...

    javascript在firefox与ie下的兼容性总结

    JavaScript在Firefox和IE之间的兼容性问题一直是前端开发者面临的一大挑战。由于这两个浏览器内核的不同,导致在处理某些JavaScript特性时存在差异。以下是一些常见的兼容性问题及其解决方案: 1. **Document.form....

    css兼容性(IE 和 firefox)技巧大全.doc

    以上技巧是针对IE和Firefox之间CSS兼容性问题的一些常见解决策略。在实际开发中,还需要注意DOCTYPE声明的使用,以确保W3C标准的遵循。同时,随着浏览器的更新,一些旧的兼容性问题可能已经得到解决,但仍需要关注新...

    IE和Firefox对JavaScript的兼容

    再者,CSS样式和JavaScript的交互在IE和Firefox上也有区别。IE有时会忽视标准的style属性,而是使用专有的currentStyle属性来获取元素的样式,而Firefox使用window.getComputedStyle()。此外,对于某些CSS属性,如...

    Javascript在IE和FireFox中的兼容处理

    以上只是JavaScript在IE与Firefox中兼容性问题的一部分,实际开发中可能遇到更多细节。解决这些问题需要对两种浏览器的特性有深入理解,并使用条件注释、polyfills和现代JavaScript库(如jQuery)来确保代码在各种...

    让IE和火狐同时兼容

    特别是在早期的Web时代,Internet Explorer(简称IE)与Mozilla Firefox(简称火狐)这两款浏览器之间存在着显著的差异,这使得页面设计师不得不花费大量时间去解决它们之间的兼容性问题。本文将详细介绍如何使网站...

    IE6、_IE7、IE8、Firefox兼容性问题

    以下是一些解决IE6、IE7、IE8和Firefox兼容性问题的方法和知识点: 1. **条件注释和doctype声明**: 在HTML中,可以使用条件注释(Conditional Comments)来针对特定版本的IE应用特定的CSS或脚本。例如,`...

    IE FIREFOX兼容性测试

    综上所述,“IE FIREFOX兼容性测试”是为了确保网站在IE和Firefox这两个重要浏览器上的良好体验。开发者应重视兼容性测试,并学习和掌握相应的解决策略,以提高网页的跨浏览器兼容性。提供的“IE-FIREFOX兼容.html”...

    让CSS兼容IE和Firefox的技巧集合

    标题中的“让CSS兼容IE和Firefox的技巧集合”是指在网页设计中,针对Internet Explorer(IE)和Firefox这两种浏览器之间CSS样式兼容性问题的解决策略。描述中的“嘿呌,IE不再是个bug”暗示了这些技巧能帮助开发者...

    JS和CSS的IE和Firefox兼容性

    在Web开发中,JavaScript(JS)和CSS的跨浏览器兼容性是开发者必须面对的重要挑战,尤其是针对用户基数庞大的Internet Explorer(IE)和Mozilla Firefox(MF)。本文将详细介绍一些常见的兼容性问题及解决方案。 ...

    javascript和css在IE和Firefox中的不同点及解决兼容性的方案

    JavaScript 和 CSS 在不同的浏览器之间可能存在兼容性问题,尤其是在 Internet Explorer (IE) 和 Mozilla Firefox 这两个浏览器中。本文将详细探讨这些差异,并提供相应的解决策略,以确保网站在各种浏览器中都能...

    IE和Firefox之间兼容性问题

    本文详细介绍了IE和Firefox浏览器之间的CSS兼容性问题,并提供了相应的解决方案。虽然现代浏览器已经逐渐改进了对CSS的支持,但在开发过程中仍然需要注意这些细节,以确保网站在不同浏览器中都能获得良好的用户体验...

    CSS兼容IE和Firefox的技巧集合

    本文将深入探讨解决CSS在IE和Firefox之间兼容性问题的一些关键技巧。 首先,理解盒模型差异是解决兼容性问题的第一步。IE6、7使用了其独有的“怪异盒模型”,其中元素宽度包括了边框和内填充,而Firefox等其他...

    IE和Firefox的Javascript兼容性总结.docx

    JavaScript 兼容性问题在开发跨浏览器的网页应用时至关重要,尤其是针对IE和Firefox这两个具有显著差异的浏览器。本文将详细探讨这些差异,并提供相应的兼容性处理方案。 首先,我们来看函数和方法的差异。在...

    css和javascript在IE和Firefox中二十三个不同点

    CSS和JavaScript在Internet Explorer(IE...为了确保代码在IE和Firefox上的兼容性,开发者通常需要使用条件注释、特性检测或者库(如jQuery)来处理这些差异。理解并适当地处理这些差异是构建跨浏览器兼容网站的关键。

Global site tag (gtag.js) - Google Analytics