2016年4月23日
Last updated
Last updated
[TOC]
CSS hack CSS hack是通过在CSS样式中加入一些特殊的符号,让不同的浏览器识别不同的符号(什么样的浏览器识别什么样的符号是有标准的,CSS hack就是让你记住这个标准),以达到应用不同的CSS样式的目的,比如.kwstu{width:300px; _ width:200px;},一般浏览器会先给元素使用width:300px;的样式,紧接着后面还有个_width:200px;由于下划线_width只有IE6可以识别,所以此样式在IE6中实际设置对象的宽度为200px,后面的把前面的给覆盖了,而其他浏览器不识别_width不会执行_width:200px;这句样式,所以在其他浏览器中设置对象的宽度就是300px;
margin属性在ie6中显示的距离会比其他浏览器中显示的距离宽2倍
浏览器识别字符标准对应表
从上图可以分析出以下几种情况:
大部分特殊字符IE浏览器支持,其他主流浏览器firefox,chrome,opera,safari不支持 (opera可识别除外)。
\9 :所有IE浏览器都支持
_和- :仅IE6支持
* :IE6、E7支持
\0 :IE8、IE9支持,opera部分支持
\9\0 :IE8部分支持、IE9支持
\0\9 :IE8、IE9支持
hack汇总
html头部hack
HTML头部引用(if IE)Hack:针对所有IE:< !--[if IE]>< !--您的代码-->< ![endif]-->,针对IE6及以下版本:< !--[if lt IE 7]>< !--您的代码-->< ![endif]-->,这类Hack不仅对CSS生效,对写在判断语句里面的所有代码都会生效。
选择器前缀hack