您现在的位置是:网站首页> 编程资料编程资料
仅针对IE8有效的CSS Hack猎奇写法_浏览器兼容教程_CSS_网页制作_
2021-09-13
1206人已围观
简介 CSS Hack的目的是兼容各种浏览器,然而IE总是个例外的存在,特别是IE8,而IE8又是Windows 7的IE的默认内置版本...偶然尝试出了仅针对IE8有效的CSS Hack猎奇写法,下面与大家分享一下:
最近做项目的时候,引用了 Google Font 的在线字体,估计是因为浏览器对字体的渲染方式不同或者是字体格式不一样,结果导致 IE8 中导航是错位的,而 IE9 和 IE10 中是正常的。
那么就需要单独为 IE8 进行一些调整,于是就需要 IE8 的 CSS hack。一看到这里,足够容易了吧?网上流传已久的 IE8 CSS hack 就是在属性后面加上 \9 或者 \0,代码如下:
- color:#FFF\0; /* IE8 */
- color:#FFF\9; /* 所有IE浏览器(ie6+) */
加上之后,发现 IE8 确实是没有问题了,但是 IE9 和 IE10 却出现了问题,上面的 hack 同样对 IE9 和 IE10 起作用。
好吧,这个 CSS hack 不是 IE8 特有的。那怎么做才能只针对 IE8 做 hack 呢?
这里的思路需要稍稍转换一下:可以先应用 IE8 的 hack ,与非 IE 浏览器分开,然后再应用一些 CSS3 之类的 IE8 不支持的选择器来重新覆盖一遍,让支持新选择器的 IE9、IE10 正常显示。符合条件的常用选择器有 :root,于是就可以写出下面代码:
- .section-nav li a {
- display: block;
- padding: 10px 13px;
- padding: 10px 7px 10px 7px \9;
- border-right: 1px solid #d7d7d7;
- }
- :root .section-nav li a {
- padding: 10px 13px 10px 13px;
- }
这样就做到了只对 IE8 浏览器起作用的 CSS hack,这种方法后来搜索了一下,早就有人提到了,写本文主要是介绍一下这个解决浏览器兼容性问题的思路吧。
再次感叹,微软神奇的IE,在开发中不得不让人抓狂。为IE6、IE7等等,都是比较好hack的,唯独IE8比较坑一点。
相关内容
- CSS清除浮动的常用方法优缺点分析_CSS教程_CSS_网页制作_
- CSS样式中大于号的使用及Css中处理继承方法_CSS教程_CSS_网页制作_
- 10个CSS简写/优化技巧整理_CSS教程_CSS_网页制作_
- CSS3实现粒子旋转伸缩加载动画_css3_CSS_网页制作_
- IE8的css hack \9 使用说明_浏览器兼容教程_CSS_网页制作_
- margin 负值引起的层级(z-index)问题_CSS教程_CSS_网页制作_
- 深入解析CSS中的自定义属性_CSS_网页制作_
- 比较全的CSS浏览器兼容问题整理总结_浏览器兼容教程_CSS_网页制作_
- 理解CSS浮动float、定位position_CSS教程_CSS_网页制作_
- CSS border虚线边框属性教程_CSS教程_CSS_网页制作_
