当前位置: 首页 > 图文教程 > 网页制作 > CSS样式表 > PDF、ZIP、DOC链接的标注(CSS技巧)

CSS样式表
IE6使用浮动去掉元素中的多余空白间距
CSS教程:定位属性在元素中的层级关系
SEO入门教程:自然搜索结果PPC广告和热图
21个神奇的CSS技巧
CSS 半透明度设置归纳总结[Firefox,IE,Chrome,Safari]
CSS 很酷的透明样式
百度有啊 CSS圆角实现代码
优秀的CSS 框架整理
CSS和“★”字符制做的中国国旗实现代码
基于firebug的firefox扩展 css usage
减少图片HTTP请求的方法分析
CSS 面向对象CSS FAQ
驯服CSS选择器
DIV+CSS 浮动布局完美解决方案
CSS 网页背景渐变实现代码
CSS 网页布局中的图文列表实现代码
css IE8 兼容问题的汇总
CSS 实现网页图片的预加载
web开发中怎么样使css书写规范?
div+css样式表的id和class常用命名规则

CSS样式表 中的 PDF、ZIP、DOC链接的标注(CSS技巧)


出处:互联网   整理: 软晨网(RuanChen.com)   发布: 2009-09-11   浏览: 83 ::
收藏到网摘: n/a


原文:http://www.maratz.com/blog/archives/2005/01/13/pdf-links-labeling/
翻译:http://www.176so.com/past/2007/3/17/pdf_links_labeling/
css技巧之PDF、ZIP、DOC链接的标注
有时候我们希望能明确的用小图标来标明我们的超链接的类型。是一个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; }

最后一点建议,你的小图标不要过分醒目,这会分散浏览者的注意力。