写 CSS 样式的时候,恐怕最头疼的就是各个浏览器下的兼容性问题,即 CSS hack,不同的浏览器对 CSS 的解析结果是不同的,因此会导致相同的 CSS 输出的页面效果不同,这就需要 CSS hack来解决浏览器局部的兼容性问题。使用 CSS 、 hack将会使用你的 CSS 代码部分失去作用,然后借助条件样式,使用其原 CSS 代码在一些浏览器解析,而 CSS hack代码在符合条件要求的浏览器中替代原 CSS 那部分代码。
CSS hack除了可以处理与浏览器不兼容的 CSS 代码,也能够让我们通过 CSS hack给不同版本的浏览器定制编写不同的CSS效果。
_
和星号 *
,IE7 能识别星号 *
,但不能识别下划线_
,而 firefox 两个都不能认识。
PS:条件注释只有在 IE 浏览器下才能执行,这个代码在非 IE 浏览下被当做注释视而不见。可以通过IE条件注释载入不同的 CSS、JS、HTML 和服务器代码等。
提示:有个 CSS hack 三种常见形式的更多解释,你可以查阅《CSS3学习笔记》的“CSS hack合集”部分的内容。
10、IE6浏览器
Selector {_property/**/:/**/value;} 或者: Selector {_property: value;} 或者: *html Selector {property: value;}
具体应用如下:
.demo {_width/**/:/**/100px;} 或者: .demo {_width: 100px;} 或者: *html .demo {width: 100px;}
上面具体介绍了各种版本浏览器下如何识别各种的Hack写法,包括了IE6-9以及现代版本的浏览器写法。综合上面的所述,我们针对不同浏览器的Hack写法主要分为两种从CSS选择器和CSS属性上来区别不同的Hack写法。
.css-hack {
color: red; /* 其他浏览器显示红色 */
color: blue\0; /* IE8、IE9 显示蓝色 */
+color: green; /* IE7 显示绿色 */
_color: brown; /* IE6 显示棕色 */
}
.css-hack {
color: red; /* 其他浏览器显示红色 */
color: blue\0; /* IE8、IE9 显示蓝色 */
}
<!--[if !IE]><!--> 除IE外都可识别 <!--<![endif]-->
<!--[if IE]> 所有的IE可识别 <![endif]-->
<!--[if IE 6]> 仅IE6可识别 <![endif]-->
<!--[if lt IE 6]> IE6以及IE6以下版本可识别 <![endif]-->
<!--[if gte IE 6]> IE6以及IE6以上版本可识别 <![endif]-->
<!--[if IE 7]> 仅IE7可识别 <![endif]-->
<!--[if lt IE 7]> IE7以及IE7以下版本可识别 <![endif]-->
<!--[if gte IE 7]> IE7以及IE7以上版本可识别 <![endif]-->
<!--[if IE 8]> 仅IE8可识别 <![endif]-->
<!--[if IE 9]> 仅IE9可识别 <![endif]-->
从上表可以分析出以下几种情况:
1.大部分特殊字符 IE 浏览器支持,其他主流浏览器 firefox,chrome,opera,safari不支持 (opera 可识别除外)。
2. \9 :所有 IE 浏览器都支持
3. _和- :仅 IE6 支持
4. * :IE6、E7 支持
5. \0 :IE8、IE9 支持,opera 部分支持
6. \9\0 :IE8 部分支持、IE9 支持
7. \0\9 :IE8、IE9 支持
现在写一个CSS可以这样:
#1 { color: #333; } /* Moz */
* html #1 { color: #666; } /* IE6 */
*+html #1 { color: #999; } /* IE7 */
那么在 firefox 下字体颜色显示为#333,IE6 下字体颜色显示为 #666,IE7 下字体颜色显示为#999。
CSS 布局中的居中问题
主要的样式定义如下:
body {TEXT-ALIGN: center;}
#center { MARGIN-RIGHT: auto; MARGIN-LEFT: auto; }
说明:
首先在父级元素定义 text-align: center
; 这个的意思就是在父级元素内的内容居中;对于 IE 这样设定就已经可以了。
但在 mozilla 中不能居中。解决办法就是在子元素定义时候设定时再加上margin-right: auto;margin-left: auto;
需要说明的是,如果你想用这个方法使整个页面要居中,建议不要套在一个 DIV 里,你可以依次拆出多个div,
只要在每个拆出的 div 里定义 margin-right: auto;margin-left: auto;
就可以了。
盒模型不同解释
#box{ width:600px; //for ie6.0- w\idth:500px; //for ff+ie6.0}
#box{ width:600px!important //for ff width:600px; //for ff+ie6.0 width /**/:500px; //for ie6.0-}
浮动 IE 产生的双倍距离
#box{ float:left; width:100px; margin:0 0 0 100px; //这种情况之下IE会产生200px的距离 display:inline;
//使浮动忽略}
这里细说一下 block
,inline
两个元素,Block
元素的特点是:总是在新行上开始,高度,宽度,行高,边距都可以控制(块元素);Inline
元素的特点是:和其他元素在同一行上,…不可控制(内嵌元素);
#box{ display:block; //可以为内嵌元素模拟为块元素 display:inline; //实现同一行排列的的效果 diplay:table;
IE 不认得 min-这个定义,但实际上它把正常的 width
和 height
当作有 min
的情况来使。这样问题就大了,如果只用宽度和高度,正常的浏览器里这两个值就不会变,如果只用 min-width
和 min-height
的话,IE下面根本等于没有设置宽度和高度。比如要设置背景图片,这个宽度是比较重要的。要解决这个问题,可以这样:
#box{ width: 80px; height: 35px;}html>body #box{ width: auto; height: auto; min-width: 80px; min-height: 35px;}
min-width
是个非常方便的 CSS 命令,它可以指定元素最小也不能小于某个宽度,这样就能保证排版一直正确。但 IE 不认得这个,而它实际上把 width
当做最小宽度来使。为了让这一命令在 IE 上也能用,可以把一个<div>
放到 <body>
标签下,然后为 div 指定一个类:
然后 CSS 这样设计:
#container{ min-width: 600px; width:expression(document.body.clientWidth < 600? “600px”: “auto” );}
第一个min-width
是正常的;但第2行的 width
使用了 JavaScript,这只有IE才认得,这也会让你的 HTML 文档不太正规。它实际上通过 Javascript 的判断来实现最小宽度。
清除浮动
.hackbox{ display:table; //将对象作为块元素级的表格显示}或者.hackbox{ clear:both;}
或者加入 :after
(伪对象),设置在对象后发生的内容,通常和 content
配合使用,IE 不支持此伪对象,非 IE 浏览器支持,
所以并不影响到 IE/WIN 浏览器。这种的最麻烦的……
#box:after{ content: “.”; display: block; height: 0; clear: both; visibility: hidden;}
p[id]{}div[id]{}
这个对于IE6.0和IE6.0以下的版本都隐藏,FF和OPera作用属性选择器和子选择器还是有区别的,子选择器的范围从形式来说缩小了,属性选择器的范围比较大,如p[id]
中,所有p
标签中有id
的都是同样式的。
IE捉迷藏的问题
当div应用复杂的时候每个栏中又有一些链接,DIV等这个时候容易发生捉迷藏的问题。有些内容显示不出来,当鼠标选择这个区域是发现内容确实在页面。
解决办法:对#layout
使用line-height
属性 或者给#layout
使用固定高和宽。页面结构尽量简单。
高度不适应
高度不适应是当内层对象的高度发生变化时外层高度不能自动进行调节,特别是当内层对象使用
margin
或 padding
时。
例:
#box {background-color:#eee; }
#box p {margin-top: 20px;margin-bottom: 20px; text-align:center; }
解决方法:在 P 对象上下各加 2个空的 div 对象 CSS 代码:.1{height:0px;overflow:hidden;}或者为 DIV 加上 border 属性。