什么是CSS hack?
由于不同厂商的流览器或某浏览器的不同版本(如IE6-IE11,Firefox/Safari/Opera/Chrome等),对CSS的支持、解析不一样,导致在不同浏览器的环境中呈现出不一致的页面展现效果。这时,我们为了获得统一的页面效果,就需要针对不同的浏览器或不同版本写特定的CSS样式,我们把这个针对不同的浏览器/不同版本写相应的CSS code的过程,叫做CSS hack!
CSS hack的原理
由于不同的浏览器和浏览器各版本对CSS的支持及解析结果不一样,以及CSS优先级对浏览器展现效果的影响,我们可以据此针对不同的浏览器情景来应用不同的CSS。
CSS hack分类
CSS Hack大致有3种表现形式,CSS属性前缀法、选择器前缀法以及IE条件注释法(即HTML头部引用if IE)Hack,实际项目中CSS Hack大部分是针对IE浏览器不同版本之间的表现差异而引入的。
属性前缀法(即类内部Hack):例如 IE6能识别 下划线"_"和星号" * " , IE7能识别星号" * ",但不能识别下划线"_" , IE6~IE10都认识"\9" ,但firefox前述三个都不能认识。 选择器前缀法(即选择器Hack):例如 IE6能识别*html .class{} , IE7能识别*+html .class{}或者*:first-child+html .class{} 。 IE条件注释法(即HTML条件注释Hack): 针对所有IE(注:IE10+已经不再支持条件注释): IE浏览器显示的内容 ,针对IE6及以下版本: 只在IE6-显示的内容 -> 。这类Hack不仅对CSS生效,对写在判断语句里面的所有代码都会生效。CSS hack书写顺序,一般是将适用范围广、被识别能力强的CSS定义在前面。
CSS hack方式一:条件注释法:
这种方式是IE浏览器专有的Hack方式,微软官方推荐使用的hack方式。举例如下
只在IE下生效 这段文字只在IE浏览器显示 只在IE6下生效 这段文字只在IE6浏览器显示 只在IE6以上版本生效 这段文字只在IE6以上(包括)版本IE浏览器显示 只在IE8上不生效 这段文字在非IE8浏览器显示 非IE浏览器生效 这段文字只在非IE浏览器显示
CSS hack方式二:类内属性前缀法:
属性前缀法是在CSS样式属性名前加上一些只有特定浏览器才能识别的hack前缀,以达到预期的页面展现效果。
IE浏览器各版本 CSS hack 对照表
说明:在标准模式中
[-″减号是IE6专有的hack [\9″ IE6/IE7/IE8/IE9/IE10都生效 [\0″ IE8/IE9/IE10都生效,是IE8/9/10的hack [\9\0″ 只对IE9/IE10生效,是IE9/10的hack
script type ="text/javascript" >
// alert(document测试数据patMode);
script >
style type ="text/css" >
body:nth-of-type(1) .iehack {
color : #F00 ; /* 对Windows IE9/Firefox 7+/Opera 10+/所有Chrome/Safari的CSS hack ,选择器也适用几乎全部Mobile/Linux/Mac browser */
}
.demo1,.demo2,.demo3,.demo4 {
width : 100px ;
height : 100px ;
}
.hack {
/* demo1 */
/* demo1 注意顺序,否则IE6/7下可能无法正确显示,导致结果显示为白色背景 */
background-color : red ; /* All browsers */
background-color : blue !important ; /* All browsers but IE6 */
*background-color : black ; /* IE6, IE7 */
+background-color : yellow ; /* IE6, IE7 */
background-color : gray\9 ; /* IE6, IE7, IE8, IE9, IE10 */
background-color : purple\0 ; /* IE8, IE9, IE10 */
background-color : orange\9\0 ; /* IE9, IE10 */
_background-color : green ; /* Only works in IE6 */
*+background-color : pink ; /* WARNING: Only works in IE7 ? Is it right? */
}
/* 可以通过javascript检测IE10,然后给IE10的 标签加上class=]ie10″ 这个类 */
.ie10 #hack {
color : red ; /* Only works in IE10 */
}
/* demo2 */
.iehack {
/* 该demo实例是用于区分标准模式下ie6~ie9和Firefox/Chrome的hack,注意顺序
IE6显示为:绿色,
IE7显示为:黑色,
IE8显示为:红色,
IE9显示为:蓝色,
Firefox/Chrome显示为:橘色,
(本例IE10效果同IE9,Opera最新版效果同IE8)
*/
background-color : orange ; /* all - for Firefox/Chrome */
background-color : red\0 ; /* ie 8/9/10/Opera - for ie8/ie10/Opera */
background-color : blue\9\0 ; /* ie 9/10 - for ie9/10 */
*background-color : black ; /* ie 6/7 - for ie7 */
_background-color : green ; /* ie 6 - for ie6 */
}
/* demo3
实例是用于区分标准模式下ie6~ie9和Firefox/Chrome的hack,注意顺序
IE6显示为:红色,
IE7显示为:蓝色,
IE8显示为:绿色,
IE9显示为:粉色,
Firefox/Chrome显示为:橘色,
(本例IE10效果同IE9,Opera最新版效果也同IE9为粉色)
*/
.element {
background-color : orange ; /* all IE/FF/CH/OP */
}
.element {
*background-color : blue ; /* IE6+7, doesn't work in IE8/9 as IE7 */
}
.element {
_background-color : red ; /* IE6 */
}
.element {
background-color : green\0 ; /* IE8+9+10 */
}
:root .element { background-color : pink\0 ; } /* IE9+10 */
/* demo4 */
/*
该实例是用于区分标准模式下ie6~ie10和Opera/Firefox/Chrome的hack,本例特别要注意顺序
IE6显示为:橘色,
IE7显示为:粉色,
IE8显示为:黄色,
IE9显示为:紫色,
IE10显示为:绿色,
Firefox显示为:蓝色,
Opera显示为:黑色,
Safari/Chrome显示为:灰色,
*/
.hacktest {
background-color : blue ; /* 都识别,此处针对firefox */
background-color : red\9 ; /* all ie */
background-color : yellow\0 ; /* for IE8/IE9/10 最新版opera也认识 */
+background-color : pink ; /* for ie6/7 */
_background-color : orange ; /* for ie6 */
}
@media screen and (min-width:0) {
.hacktest {background-color : black\0 ; } /* opera */
}
@media screen and (min-width:0) {
.hacktest { background-color : purple\9 ; } /* for IE9/IE10 PS:国外有些习惯常写作\0,根本没考虑Opera也认识\0的实际 */
}
@media screen and (-ms-high-contrast: active), (-ms-high-contrast: none) {
.hacktest { background-color : green ; } /* for IE10+ 此写法可以适配到高对比度和默认模式,故可覆盖所有ie10的模式 */
}
@media screen and (-webkit-min-device-pixel-ratio:0) { .hacktest {background-color : gray ; } } /* for Chrome/Safari */
/* #963棕色 :root is for IE9/IE10, 优先级高于@media, 慎用!如果二者合用,必要时在@media样式加入 !important 才能区分IE9和IE10 */
/*
:root .hacktest { background-color:#963\9; }
*/
style >
声明:本文来自网络,不代表【好得很程序员自学网】立场,转载请注明出处:http://haodehen.cn/did101888