加载中…
个人资料
陈在真Sunny_chen
陈在真Sunny_chen
  • 博客等级:
  • 博客积分:0
  • 博客访问:10,715
  • 关注人气:183
  • 获赠金笔:0支
  • 赠出金笔:0支
  • 荣誉徽章:
正文 字体大小:

Css Hack汇总

(2011-02-22 16:48:04)
标签:

css

hack

兼容

ie/ff

it

分类: CSS

1.区别不同浏览器,CSS hack写法:

区别IE6FF:
       background:orange;*background:blue;


区别IE6IE7: background:green !important;background:blue;
区别IE7FF: background:orange; *background:green;
区别FFIE7IE6: background:orange;*background:green !important;*background:blue;
区别chrome,safari: [;background: #CCCCCC;];

注:IE都能识别*;标准浏览器(如FF)不能识别*; IE6能识别*,但不能识别 !important, IE7能识别*,也能识别!important; FF不能识别*,但能识别!important;
  IE6 IE7 FF
* ×
!important ×

另外再补充一个,下划线"_",
IE6支持下划线,IE7FF均不支持下划线。

于是大家还可以这样来区分IE6IE7FF
: background:orange;*background:green;_background:blue; 

注:不管是什么方法,书写的顺序都是FF的写在前面,IE7的写在中间,IE6的写在最后面。

2.!important

随着IE7对!important的支持, !important 方法现在只针对IE6的HACK.(注意写法.记得该声明位置需要提前.)

<style>
#wrapper
{
 width: 100px!important; 
 width: 80px; 
}
</style>

3.IE6/IE7对FF

1.*+html 与 *html 是IE特有的标签, firefox 暂不支持. 而*+html 又为 IE7特有标签.

<style>
#wrapper
{
 #wrapper { width: 120px; } 
 *html #wrapper { width: 80px;} 
 *+html #wrapper { width: 60px;} 
}
</style>


2.表达方式:+property:value

测试环境:IE5,IE6 ,IE7,FF1.5,FF2.0,Opera 9,Safari 2
测试结果:
IE5,IE6 ,IE7浏览器识别;
FF2.0,Opera 9,Safari 2浏览器不识别。

结论:我们可以用"+"来实现只有IE识别的CSS Hack。

比如我们要实现在IE中500px的宽度,而在其他浏览器480px的宽度,就可以通过"+" Hack来完成,如下:

#hack {
  width:500px; 
  +width:480px; 
}


3.用于内联css

##wrapper  {
  height:20px;   
  *height:25px;  
  _height:20px;  
}


5.IE7的hack

>body
html*
*+html 

这三种写法,其中前两种都是不合法的 CSS 写法,在标准兼容浏览器中被被忽略,但是 IE7 却不这么认为。 对于 >body ,它会将缺失的选择符用全局选择符 * 代替,也就是将其处理成了 *>body,而且不光对于 > 选择符,+,~ 选择符中这个现象也存在。对于 html* ,由于 html 和 * 之间没有空格,所以也是一种 CSS 语法错误,但 IE7 不会忽略,而是错误地认为这里有一个空格。对于第三种 *+html,IE7 认为 html 前面的 DTD 声明也是一个元素,所以 html 会被选中,这三种方法中只有这一种方法是合法的 CSS 写法,也就是说可以通过校验器的验证,因此也是作者推荐的 hack 用法。 

6.IE6 不能识别

html >body  #box { color: red; }   IE6 字体不会变成红色 

7.屏蔽IE浏览器(也就是IE下不显示)

*:lang(zh) select {font:12px  !important;} 

select:empty {font:12px  !important;} 


这里select是选择符,根据情况更换。第二句是MAC上safari浏览器独有的。

8.仅IE7与IE5.0可以识别

*+html  select {…}
当面临需要只针对IE7与IE5.0做样式的时候就可以采用这个HACK。 

9.仅IE7可以识别

*+html  select {…!important;}
当面临需要只针对IE7做样式的时候就可以采用这个HACK。  

10.IE6及IE6以下识别

* html  select {…}
这个地方要特别注意很多博客都写成了是IE6的HACK其实IE5.x同样可以识别这个HACK。其它浏览器不识别。
html >body  select {…}
这句与上一句的作用相同。  

11.仅IE6不识别,屏蔽IE6

select { display :none;}
这里主要是通过CSS注释分开一个属性与值,注释在冒号前。

12.仅IE6与IE5不识别,屏蔽IE6与IE5

select { display :none;}
这里与上面一句不同的是在选择符与花括号之间多了一个CSS注释。不屏蔽IE5.5

13.仅IE5不识别,屏蔽IE5

select {…}
这一句是在上一句中去掉了属性区的注释。只有IE5不识别,IE5.5可以识别。

14.盒模型解决方法

select {width:IE5.x宽度; voice-family :"\"}\""; voice-family:inherit; width:正确宽度;}
盒模型的清除方法不是通过!important来处理的。这点要明确。

15.盒模型解决方法

select:after {content:"."; display:block; height:0; clear:both; visibility:hidden;}
在Firefox中,当子级都为浮动时,那么父级的高度就无法完全的包住整个子级,那么这时用这个清除浮动的HACK来对父级做一次定义,那么就可以解决这个问题。

16.只有Opera识别

@media all and (min-width: 0px){ select {……} }
针对Opera浏览器做单独的设定。

17.IE5.x的过滤器,只有IE5.x可见

@media tty {
i{content:"\";}} @import 'ie5win.css'; 

18.IE5/MAC的过滤器,一般用不着

@media all and (min-width: 0px){ select {……} }
针对Opera浏览器做单独的设定。

文章摘自 http://www.msleft.com/review/csshack.html 这布局比我copy的
漂亮很多啦(果真盗版的就是内容一样,但是质量就是差哈)……

0

阅读 收藏 喜欢 打印举报/Report
  

新浪BLOG意见反馈留言板 欢迎批评指正

新浪简介 | About Sina | 广告服务 | 联系我们 | 招聘信息 | 网站律师 | SINA English | 产品答疑

新浪公司 版权所有