有一个奇怪的 IE 问题一直困扰着我。它在其他浏览器(Chrome / Firefox)中正常工作。
对于那些想直接深入代码的人来说,这里有一个 Fiddle。重要部分:
HTML:
<a href="#" class="btn">MyButton</a>
CSS:
.btn {
display:block; width:135px; height:58px; text-indent: -9999px;
background-image:url("http://i47.tinypic.com/e7f4w6.png");
}
.btn:hover { background-position:bottom; }
在小提琴中,我添加了一个箭头来显示图像的正确“中心”。如您所见,这只是一个用于导航的简单图像精灵。图片的高度是实际按钮高度的两倍,所以我们可以应用background-position:bottom
.
但由于某种原因,当鼠标悬停时,IE 无法正确显示图像。不知何故,箭头(黑线)和中心线(悬停状态下的红线)不再对齐:
正常状态:
悬停状态:
因为行“跳跃”,文本也跳跃(在我的示例中几乎看不到,但在我的项目中你会看到它非常好)。在 Win7 上使用 IE9 及更低版本测试并发生。
我希望你能找到这个小脑筋急转弯的解决方案!