• 欢迎访问搞代码网站,推荐使用最新版火狐浏览器和Chrome浏览器访问本网站!
  • 如果您觉得本站非常有看点,那么赶紧使用Ctrl+D 收藏搞代码吧

用!important解决IE和Mozilla的布局差别_css

css 搞代码 7年前 (2018-06-10) 201次浏览 已收录 0个评论

作者:阿捷 2004-7-24 14:56:36

在设计《网页设计师》页面的时候,有一个问题一直困扰着我,主菜单在IE和其他(Mozilla、Opera等)浏览器里显示的效果偏差2px。截图如下:

IE中的效果

用!important解决IE和Mozilla的布局差别_css

Mozilla Firefox中的效果

用!important解决IE和Mozilla的布局差别_css

这是因为IE对盒之间距离的解释的bug造成的(参考onestab的” 浮动模型的问题 “)。我一直没有解决这个问题,直到我翻译 “CSS–一场生死之战” rel=”next” target=”new”>表格对决CSS–一场生死之战 “时,作者的一个技巧提示帮我找到了解决的方法:用!important。

!important是CSS1就定义的语法,作用是提高指定样式规则的应用优先权(参见:CSS2/cascade.html#important-rules”>W3.org的解释)。语法格式{ sRule!important },即写在定义的最后面,例如:

box{color:red !important;}

最重要的一点是:IE一直都不支持这个语法,而其他的浏览器都支持。因此我们就可以利用这一点来分别给IE和其他浏览器不同的样式定义,例如,我们定义这样一个样式:

.colortest { border:20px  solid #60A179 !important;border:20px  solid #00F;padding: 30px;width : 300px;} 

在Mozilla中浏览时候,能够理解!important的优先级,因此显示#60A179的颜色:

用!important解决IE和Mozilla的布局差别_css

在IE中浏览时候,不能够理解!important的优先级,因此显示#00F的颜色:

用!important解决IE和Mozilla的布局差别_css

可以看到,利用!important,我们可以针对IE和非IE浏览器设置不同的样式,只要在非IE浏览器样式的后面加上!important。因此,上面提到的我的主页2px的显示差别也轻松解决:

PADDING-TOP: 11px !important;
PADDING-TOP: 9px;

!important必定成为css布局的利器,请记住和掌握它吧:)

欢迎大家阅读《用!important解决IE和Mozilla的布局差别…_css》,跪求各位点评,若觉得好的话请收藏本文,by 搞代码


搞代码网(gaodaima.com)提供的所有资源部分来自互联网,如果有侵犯您的版权或其他权益,请说明详细缘由并提供版权或权益证明然后发送到邮箱[email protected],我们会在看到邮件的第一时间内为您处理,或直接联系QQ:872152909。本网站采用BY-NC-SA协议进行授权
转载请注明原文链接:用!important解决IE和Mozilla的布局差别_css

喜欢 (0)
[搞代码]
分享 (0)
发表我的评论
取消评论

表情 贴图 加粗 删除线 居中 斜体 签到

Hi,您需要填写昵称和邮箱!

  • 昵称 (必填)
  • 邮箱 (必填)
  • 网址