`

<转>CSS HACK经典收藏

    博客分类:
  • css
 
阅读更多
1.区别不同浏览器,CSS hack写法:

区别IE与FF:用 *  星号background:orange;*background:blue;区别IE6与IE7,ff:background:green!important;background:blue;区别IE7与FF:background:orange;*+background:green; // *+ ie7识别区别FF,IE7,IE6:background:orange;*background:green;_background:blue;注:IE都能识别*;标准浏览器(如FF)不能识别*;IE6能识别*和_,但不能识别 !important,IE7能识别*,也能识别!important;FF不能识别*和_,但能识别!important;另外再补充一个,下划线"_",IE6支持下划线,IE7和FF均不支持下划线。于是大家还可以这样来区分IE6,IE7,FF: background:orange;*background:green;_background:blue; 注:不管是什么方法,书写的顺序都是FF的写在前面,IE7的写在中间,IE6的写在最后面。

 
2.!important
随着IE7对!important的支持, !important 方法现在只针对IE6的HACK.(注意写法.记得该声明位置需要提前.)<style>#wrapper{width: 100px!important; /* IE7+FF */width: 80px; /* IE6 */}</style> 

3.IE6/IE7对FF


1.*+html 与 *html 是IE特有的标签, firefox 暂不支持.而*+html 又为 IE7特有标签.
<style>#wrapper{#wrapper { width: 120px; } /* FireFox */*html #wrapper { width: 80px;} /* ie6 fixed */*+html #wrapper { width: 60px;} /* ie7 fixed, 注意顺序 */}</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中480px的宽度,而在其他浏览器500px的宽度,就可以通过"+" Hack来完成,如下:#hack {width:500px;+width:480px; /*only IE*/}


3.用于内联css#

#wrapper  {height:20px;   /*For Firefox*/*height:25px;  /*For IE7 & IE6*/_height:20px;  /*For IE6*/}


5.IE7的hack>

bodyhtml**+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;}/*FF,OP可见,特别提醒:由于Opera最近的升级,目前此句只为FF所识别*/select:empty {font:12px  !important;}/*safari可见*/这里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 /*屏蔽IE6*/:none;}这里主要是通过CSS注释分开一个属性与值,注释在冒号前。


12.仅IE6与IE5不识别,屏蔽IE6与IE5select/**/ { display /*IE6,IE5不识别*/:none;}这里与上面一句不同的是在选择符与花括号之间多了一个CSS注释。不屏蔽IE5.5


13.仅IE5不识别,屏蔽IE5select/*IE5不识别*/ {…}这一句是在上一句中去掉了属性区的注释。只有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浏览器做单独的设定
分享到:
评论

相关推荐

    css之链接显示 <a></a>

    css之链接显示 &lt;a&gt;&lt;/a&gt; css之链接显示 &lt;a&gt;&lt;/a&gt;

    CSS文集

    利用CSS的Expression自定义属性来实现表格的OnMouseOver 特效&lt;br&gt;需要掌握的八个CSS布局技巧&lt;br&gt;用css实现链接经过时显示浮动图片背景的效果&lt;br&gt;...Firefox和IE6兼容的垂直居中&lt;br&gt;CSS&lt;br&gt;CSS浮动原理&lt;br&gt;CSS网站元素设计...

    使用CssBox+itext实现jsp页面转图片并导出pdf

    pom文件如下: &lt;dependency&gt; &lt;groupId&gt;com.itextpdf&lt;/groupId&gt; &lt;artifactId&gt;itextpdf&lt;/artifactId&gt; &lt;version&gt;5.5.12&lt;/version&gt; ... &lt;artifactId&gt;cssbox&lt;/artifactId&gt; &lt;version&gt;4.13&lt;/version&gt; &lt;/dependency&gt;

    Dreamweaver网页设计

    形考任务二 活动1:采用CSS样式来设置背景、标题和段落的颜色。 ... &lt;html&gt; &lt;head&gt; &lt;/head&gt; ...&lt;body&gt; ...&lt;/body&gt; ...&lt;/html&gt; ...&lt;html&gt; ...&lt;head&gt; ...&lt;/head&gt; ...&lt;body&gt; ...&lt;/body&gt; ...&lt;style type="text/css"&gt; body {backgr

    CSS3 3D立体文字变色发光动画特效.zip

     &lt;h1&gt;3d CSS GLOW&lt;/h1&gt;  &lt;h1&gt;3d CSS GLOW&lt;/h1&gt;  &lt;h1&gt;3d CSS GLOW&lt;/h1&gt;  &lt;h1&gt;3d CSS GLOW&lt;/h1&gt;  &lt;h1&gt;3d CSS GLOW&lt;/h1&gt;  &lt;h1&gt;3d CSS GLOW&lt;/h1&gt;  &lt;h1&gt;3d CSS GLOW&lt;/h1&gt;  &lt;h1&gt;3d CSS GLOW&lt;/h1&gt;  &lt;h1&gt;3d...

    网页教程代码参考

    &lt;br&gt;HTML&lt;br&gt;HTML教程&lt;br&gt;&lt;br&gt;HTML代码示例&lt;br&gt;&lt;br&gt;HTML参考(Reference)&lt;br&gt;&lt;br&gt;HTML知识库&lt;br&gt;&lt;br&gt;CSS&lt;br&gt;CSS教程&lt;br&gt;&lt;br&gt;CSS代码示例&lt;br&gt;&lt;br&gt;CSS参考(Reference)&lt;br&gt;&lt;br&gt;Javascript&lt;br&gt;Javascript教程&lt;br&gt;&lt;br&gt;...

    网页制作完全手册

    &lt;br&gt;&lt;br&gt;动态 HTML (DHTML) 对象模型参考&lt;br&gt;&lt;br&gt;DHTML 对象 &lt;br&gt;DHTML 属性 &lt;br&gt;DHTML 方法 &lt;br&gt;DHTML 事件 &lt;br&gt;DHTML 集合 &lt;br&gt;HTML 参考&lt;br&gt;&lt;br&gt;HTML 元素 &lt;br&gt;HTML 字符集 &lt;br&gt;样式表(CSS)参考&lt;br&gt;&lt;br&gt;CSS 属性...

    DHTML 手册中文文档

    HTML (DHTML) 对象模型参考&lt;br&gt;&lt;br&gt;DHTML 对象 &lt;br&gt;DHTML 属性 &lt;br&gt;DHTML 方法 &lt;br&gt;DHTML 事件 &lt;br&gt;DHTML 集合 &lt;br&gt;HTML 参考&lt;br&gt;&lt;br&gt;HTML 元素 &lt;br&gt;HTML 字符集 &lt;br&gt;样式表(CSS)参考&lt;br&gt;&lt;br&gt;CSS 属性参考 ...

    DHTML对象模型参考手册

    &lt;br&gt;&lt;br&gt;动态 HTML (DHTML) 对象模型参考&lt;br&gt;&lt;br&gt;DHTML 对象 &lt;br&gt;DHTML 属性 &lt;br&gt;DHTML 方法 &lt;br&gt;DHTML 事件 &lt;br&gt;DHTML 集合 &lt;br&gt;HTML 参考&lt;br&gt;&lt;br&gt;HTML 元素 &lt;br&gt;HTML 字符集 &lt;br&gt;样式表(CSS)参考&lt;br&gt;&lt;br&gt;CSS 属性...

    WEB完全手册

    &lt;br&gt;&lt;br&gt;动态 HTML (DHTML) 对象模型参考&lt;br&gt;&lt;br&gt;DHTML 对象 &lt;br&gt;DHTML 属性 &lt;br&gt;DHTML 方法 &lt;br&gt;DHTML 事件 &lt;br&gt;DHTML 集合 &lt;br&gt;HTML 参考&lt;br&gt;&lt;br&gt;HTML 元素 &lt;br&gt;HTML 字符集 &lt;br&gt;样式表(CSS)参考&lt;br&gt;&lt;br&gt;CSS 属性...

    WEB开发完全手册

    &lt;br&gt;&lt;br&gt;动态 HTML (DHTML) 对象模型参考&lt;br&gt;&lt;br&gt;DHTML 对象 &lt;br&gt;DHTML 属性 &lt;br&gt;DHTML 方法 &lt;br&gt;DHTML 事件 &lt;br&gt;DHTML 集合 &lt;br&gt;HTML 参考&lt;br&gt;&lt;br&gt;HTML 元素 &lt;br&gt;HTML 字符集 &lt;br&gt;样式表(CSS)参考&lt;br&gt;&lt;br&gt;CSS 属性...

    CSS简明教程

    &lt;br&gt;背景附件 &lt;br&gt;背景位置 &lt;br&gt;背景 &lt;br&gt;&lt;br&gt;&lt;br&gt;文本属性&lt;br&gt;&lt;br&gt;文字间隔 &lt;br&gt;字母间隔 &lt;br&gt;文字修饰 &lt;br&gt;纵向排列 &lt;br&gt;文本转换 &lt;br&gt;文本排列 &lt;br&gt;文本缩进 &lt;br&gt;&lt;br&gt;行高&lt;br&gt;&lt;br&gt;方框属性&lt;br&gt;&lt;br&gt;上边界 &lt;br&gt;...

    使用HTML开发商业网站-CSS3核心基础课件.pptx

    &lt;head&gt;&lt;title&gt;使用 css 方式&lt;/title&gt; &lt;style&gt; h1 {text-align:center; border-bottom:1px solid black;} &lt;/style&gt; &lt;/head&gt; &lt;body&gt; &lt;h1&gt;一级标题&lt;/h1&gt; &lt;p&gt;…其他正文…&lt;/p&gt; &lt;h1&gt;一级标题&lt;/h1&gt; &lt;/body&gt; &lt;/html&gt; CSS的...

    用css固定表格横向和纵向

    &lt;link rel="stylesheet" href="css/style.css"&gt; &lt;/head&gt; &lt;body&gt; &lt;div role="region" aria-label="data table" tabindex="0" class="primary"&gt; &lt;table&gt; &lt;thead&gt; &lt;tr&gt; &lt;th&gt;Col Header&lt;/th&gt; &lt;th &gt;2&lt;/th&gt; &lt;th&gt;Col...

    css 导航菜单(标签页)设计

    title="Link 1"&gt;&lt;span&gt;Link 1&lt;/span&gt;&lt;/a&gt;&lt;/li&gt;&lt;br&gt;&lt;li&gt;&lt;a href="#" title="Link 2"&gt;&lt;span&gt;Link 2&lt;/span&gt;&lt;/a&gt;&lt;/li&gt;&lt;br&gt;...&lt;br&gt;&lt;/ul&gt;&lt;br&gt;&lt;/div&gt;&lt;br&gt;&lt;br&gt;效果页面,css和html写得很清楚。&lt;br&gt;下载html打包文件&lt;br&gt;

    C#编程经验技巧宝典

    58&lt;br&gt;&lt;br&gt;0081 文本中首字母改为大写 59&lt;br&gt;&lt;br&gt;0082 C#随机数的产生 59&lt;br&gt;&lt;br&gt;0083 身份证从15位升至18位算法 60&lt;br&gt;&lt;br&gt;0084 十进制数转二进制数的算法 60&lt;br&gt;&lt;br&gt;0085 十进制数转八进制数的算法 61...

    DHTLM,HTML,CSS 网页制作完全参考手册

    140KB &lt;br&gt;wsh.chm Microsoft Windows 脚本宿主 136KB &lt;br&gt;MSXML.chm Microsoft XML 4.0 Technology Preview 2.37MB &lt;br&gt;css.chm css 2.0 中文手册(苏昱) 258KB &lt;br&gt;cssfilter.chm 样式表滤镜中文手册(苏昱) 386KB ...

    asp.net博客

    样式文件是各个后台页面的样式&lt;br&gt; IndexCss.css&lt;br&gt; AdminCss.css在admin.aspx页面中引用&lt;br&gt; AdminLoginCss.css在Login.aspx页面中引用&lt;br&gt; AdminLeftCss.css在left.aspx页面中引用&lt;br&gt; AdminRightCss.css在Right....

Global site tag (gtag.js) - Google Analytics