5

像所有思想正确的人一样,我讨厌单击链接并发现它导致浏览器瘫痪的 PDF 或 Microsoft Office 文件为时已晚。我想通过在指向此类文件的链接旁边显示一个小图标,我会让人们的生活更轻松一些。随着 IE8 终于支持:after伪元素,我认为 CSS 声明会相当简单:

a.file_pdf:after {
    content:url('/images/pdf.png');
    text-decoration: none;
    padding-left: 5px;
}

在 IE8 中,这工作正常。但是,在 Firefox 和 Chrome 中,它text-decoration: none被忽略了,并且下划线毫无吸引力地延伸到了图标的底部。有没有办法通过使用额外的<span>标签来解决这个问题而不会“作弊”?

4

2 回答 2

5

我正在以不同的方式使用属性选择器、背景图像和填充(正如xandy 也建议的那样):

a[href$=".pdf"] {
  padding-right: 21px; /* space for the icon */
  background: url(graphics/pdf.png) no-repeat right bottom;
}

这也适用于 IE7。

这是一个完整的例子

在 IE7 中,PDF 图标将不可见,因为它不理解数据 URI:

<!DOCTYPE html>

<html>
<head>
<meta charset="UTF-8">
<title>PDF</title>
<style type="text/css">
a:link,
a:visited {
  color: #317408;
  background: #eee;
}
a[href$=".pdf"] {
  padding-right: 21px;
  background-image: url();
  background-repeat: no-repeat;
  background-position: right bottom;
}
a:hover {
  color: #eee;
  outline: none;
  background-color: #317408;
  text-decoration: none;
}
</style>
</head>
<body>

<p>
   <a href="document.pdf">Here's the PDF</a>
</p>

</body>
</html>
于 2009-07-25T01:45:10.700 回答
1

如何使用背景图像?

a.file_pdf {
    background: url('/images/pdf.png') no-repeat right;
    padding-right: 30px;
    ...
}

编辑

在我的 FF 3.5 上测试并完美运行,在大多数浏览器中应该没有问题,因为只使用传统的图像替换技术。

于 2009-07-25T01:43:30.017 回答