区分IE8 、IE9 的专属css hack


般来说,我们写的结构比较好的时候,IE8/9下是没区别的.所以可能很少人关注只有IE8或只有IE9才识别的css hack.

因为IE8及以下版本是不支持CSS3的,但是我们如果使用css3,在IE下IE9正常渲染,但我们又想让IE8及以下的浏览器实现同样的效果,且不希望使用css3pie或htc或条件注释等方法时,可能就会需要用到IE8和IE9的专属css hack了.


.test{ /* 1. */

/* color:#09F; 以前是IE8/9, 现在10也支持 */

color:#09F/; /* 以前是IE8 only, 现在IE9/10也支持. 如要排除IE9需要使用下面的rule重设IE9样式 */

}

@media all and (min-width:0) { /* 2. */

.test{color:red9; }/* IE9 only, 现在IE10也支持 */

/* Ps:老外的方法都是,根本没考虑Opera */

}

@media screen and (-ms-high-contrast: active), (-ms-high-contrast: none) { /* 3. */

.test { color: green; } /* IE10+ */

}

:root .test { color:#9639; } /* 以前IE9 only, 现在10也支持, 优先级高于@media, 优先级太高, 尽量少用 */

注: IE老不按规矩, 以前IE8 only/IE9 only的hack, IE10 一出现都乱套了~ 为了避免看此文的同学失望而归, 从新又整理了一下内容(2013-01-28), 如有错误望指出. 现在, 要想写出专门针对ie8或ie9的hack, 把1/2/3种组合在一起使用. 如果可以, 使用CSS条件注释更靠谱.


豫ICP备12024565号-1   E-mail:admin@hlc8.com