• 博客园logo
  • 会员
  • 众包
  • 新闻
  • 博问
  • 闪存
  • 赞助商
  • HarmonyOS
  • Chat2DB
    • 搜索
      所有博客
    • 搜索
      当前博客
  • 写随笔 我的博客 短消息 简洁模式
    用户头像
    我的博客 我的园子 账号设置 会员中心 简洁模式 ... 退出登录
    注册 登录
Joanna Qian
Stay Hungry, Stay Foolish!
博客园    首页    新随笔    联系   管理    订阅  订阅
PDF、ZIP、DOC链接的标注(CSS技巧)

原文:http://www.maratz.com/blog/archives/2005/01/13/pdf-links-labeling/
翻译:http://www.176so.com/past/2007/3/17/pdf_links_labeling/

有时候我们希望能明确的用小图标来标明我们的超链接的类型。是一个zip文档还是一个pdf文件。这样访问者就知道他所要点击的这个链接是下载而不是打开另一个页面了。如果所有的人都使用IE7或者FF的话。我们完全可以使用[att$=val]属性选择器,寻找以特定值(比如.zip和.doc)结尾的属性。

a[href$=".pdf"] { padding-right: 19px; background: url(pdf.gif) no-repeat 100% .5em; }
a[href$=".zip"] { padding-right: 17px; background: url(zip.gif) no-repeat 100% .5em; }

不幸的是IE6以下浏览器不支持属性选择器。好在,可以通过在每个元素中添加类,使用JavaScript和DOM实现相似的效果。
下面给出了一个解决办法:

function fileLinks() {
var fileLink;
if (document.getElementsByTagName('a')) {
   for (var i = 0; (fileLink = document.getElementsByTagName('a')[i]); i ) {
      if (fileLink.href.indexOf('.pdf') != -1) {
          fileLink.setAttribute('target', '_blank');
          fileLink.className = 'pdfLink';
      }
      if (fileLink.href.indexOf('.doc') != -1) {
          fileLink.setAttribute('target', '_blank');
          fileLink.className = 'docLink';
      }
      if (fileLink.href.indexOf('.zip') != -1) {
          fileLink.setAttribute('target', '_blank');
          fileLink.className = 'zipLink';
      }
   }
 }
}
window.onload
= function() { fileLinks(); }

当然,你需要在你的css文件中,增加这几个css类:

.pdfLink { padding-right: 19px; background: url(pdf.gif) no-repeat 100% .5em; }
.docLink { padding-right: 19px; background: url(doc.gif) no-repeat 100% .5em; }
.zipLink { padding-right: 17px; background: url(zip.gif) no-repeat 100% .5em; }

最后一点建议,你的小图标不要过分醒目,这会分散浏览者的注意力
详细出处参考:http://www.jb51.net/css/6860.html

posted on 2012-08-27 23:30  Joanna Qian  阅读(412)  评论(0)    收藏  举报
刷新页面返回顶部
博客园  ©  2004-2025
浙公网安备 33010602011771号 浙ICP备2021040463号-3