基于链接关系的微格式 使用rel属性

所属分类: 网页制作 / CSS 阅读数: 970
收藏 0 赞 0 分享

原文链接:http://www.ablognotlimited.com/articles/getting-semantic-with-microformats-part-1-rel/

这篇文章作为第一篇介绍会主要集中在基于链接关系的微格式,使用rel 属性。现在让我们开始吧。

基于链接的关系

rel 属性通常用来描述链接之间的关系,也就是说目的地址 (href) 跟源(站点)之间的关系。大部分人可能非常熟悉这个属性,因为他常常被用来描述CSS的链接地址:

<link rel=”stylesheet” type=”text/css” media=”screen” href=”/styles/main.css” />

此外,在这个标记中您可以使用多个 rel 值,就好像可以在 class 属性中使用多个值一样。

告诉我回家的路

rel-home 微格式用来指明链接的目的地址是该站点的首页。这个微格式的首要目的是为了导航使用的,但是同时也为页面提供了站点结构的描述信息。

注意: rel-home 目前还处在标准提案阶段,这也就意味着他还是个变数。但是,既然变化本身就是互联网技术的特性,我不是很在意这一点。

现在我们回到编程上面来……我在两种情况下会使用 rel-home 微格式。在我的 XHTML 代码的 <head> 部分,我会添加:

<link rel=”home” href=”http://www.ablognotlimited.com/” title=”Home page” />

同样,任何指向首页的链接(例如在导航处,当然也可以包括正文中)都会被指定这个属性 rel="home"

<a href="http://www.ablognotlimited.com" rel=”home”>A Blog Not Limited</a>

这样做的好处

除了提供语义的基本描述,Opera 会自动识别出文档<head>段中<link>的rel-home属性。Opera浏览器会提供一个导航的工具条──如果启用的话──允许用户使用该工具条进行站内导航:
Opera Navigation Toolbar

同样的,根据Mark Pilgrim的文章Dive Into Accessibility,rel-home 属性也会为文本模式的浏览器提供更强大的导航辅助,提升软件的无障碍使用特性,例如文本模式浏览器LinksLynx都会检测该属性。

最后,rel-home 可以被Firefox附加组件 cmSiteNavigation工具条识别,会在工具条中显示一些导航辅助信息。目前,这个附加组件可以在FFFFFFFF 1.5–2.0版本上使用,但是我现在使用FF 3.0,所以不能帮助提供截图了。FFFFFFFF 1.5–2.0版本上使用,但是我现在使用FF 3.0,所以不能帮助提供截图了。

我和我的

同样,既然这是我的博客,并且rel可以使用多个属性值,所以,所有指向首页的链接也都被指定rel="me"的属性:

<a href="http://www.ablognotlimited.com" rel=”home me”>A Blog Not Limited</a>

根据微格式的详细说明rel="me"可以被使用在用来描述从描述某人的页面到另一个同样描述该人页面的超链接。

记住了这一点,我把指向我社交站点(比如,Flickr、Facebook、Twitter等)个人页面的链接上都添加了 rel="me"属性:

<a href="http://twitter.com/emilylewis" rel=”me”>Twitter</a>

好处

属性提供的语义描述已经让我非常的满意了,在此之外,使用 rel-me 属性有越来越多的好处浮现出来,主要是使用在描述XFN之间的关系上。

XFN(XHTML 好友网络的缩写)是一个用来描述社交关系(例如,好友、家庭、同事等)的微格式。Google正在使用XFN来开发Social Graph API来帮助网络变得更加社区化,使的在任何网站上寻找朋友都变成一件非常容易的事情。

同样的,有越来越多的“在线身份集合(online identity consolidation)”的服务使用XFN,包括 claimIDPlaxo’s Open Social Graph

此外,大量的社交网络站点开始在他们的资料页链接中添加 rel="me",包括Flickr、Twitter、LinkedIn等。这些行动都在支持着“在线身份集合”:在任何使用其他身份的网页中,分散的个人身份被重新集合在一起。(译注:好晦涩,不会翻)

我会在这个系列文章的第二部分中更具体的来讲述XFN。

分类 + 标签 = 令人兴奋的组织性

由于我对组织性特别的偏好(也因为所有非常COOL的孩子都这么做),我在博客中使用“标签”来配合“分类”功能。恰恰有一个微格式是支持这个组织结构的:rel-tag

给链接(<a>) 添加 rel="tag" 属性可以表明 该网页──或者该网页的一部分──是关于什么的。rel-tag广泛的在博客中使用,作者通常使用标签来标注他们的文章,从而帮助组织和分类他们的内容。

规范要求链接的目的地址 (href) 的URL中最后一部分要包含“标签”的实际赋值。这种链接的组织方式也被称作“标签空间(tagspace)”。

在 A Blog Not Limited 博客上,我对所有的标签链接逗应用了这个微格式:

<a href="http://www.ablognotlimited.com/articles/tag/ExpressionEngine/” rel=”tag”>ExpressionEngine</a>

同样,对于我所有的分类链接:

<a href="http://www.ablognotlimited.com/articles/category/experiments/” rel=”tag”>Experiments</a>

这些例子说明在使用这些链接的页面中包含了描述“ExpressionEngine”和“Experiments”的内容。此外,这些例子还说明“ExpressionEngine”和“Experiments”定义的标签空间可以使用这些链接来定位。

好处

还需要多说吗?是的,因为我喜欢这么说:语义是这些微格式带给我最首要的好处。同样,在同时使用本文中描述的其他微格式时,会带来更多的好处。

例如,Firefox的附加组件 Operator 会自动发现 rel-tag 然后提供该标签进行上下文相关的搜索,这些搜索来自于Amazon、YouTube和Flickr这样的网站。下图就是 Operator 如何使用我博客上的 rel-tag 属性的:

Operator Firefox Add-On

Technorati 提供 标签搜索的服务,用来索引这些使用标签的博客文章和内容。这会帮助那些站点和博客进行传播,因为用户完全可以通过访问 Technorati的标签服务 来搜索到这些被索引的文章。博客搜索引擎 Icerocket 也支持 基于标签的搜索.

License to Kill (With Semantics)

是的,我知道,非常烂 继续……

我使用的最后一个基于链接的关系微格式是rel-license。可能您早已经猜到了,这个微格式用来描述内容的版权,使用在那些指向版权信息的链接(<a>)中(通过href值)。

当我开始“A Blog Not Limited”,做的第一件事情就是获取一份Creative Commons的版权来保护我的内容。之后,在页脚部分修改了版权声明,就包含了一条这样的链接,我为他添加了rel="license"属性:

<a href="http://creativecommons.org/licenses/by-nc-nd/3.0/" title="Creative Commons Attribution-Noncommercial-No Derivative Works 3.0 Unported" rel=”license”>copyright</a>

好处

Yep,语义!之外的好处就是,同样有一个FF的附加组件可以识别rel-license:Tails Export。下图是Tails显示博客上的版权信息:

Tails Export Firefox Add-On

Creative Commons 在生成版权标记的时候也使用rel-license

同样,Google和Yahoo!也提供基于rel-licensed内容过滤的搜索:

全面使用的好处

上面分别讲述了每个微格式使用的好处,同样需要注意的还有一个全面的好处就是:CSS属性选择器

通过使用CSS属性选择器,您可以为不同rel属性的链接定义特定的风格。例如,为指定rel="license"的链接添加一个图标:

a[rel~="license"]:before {content: url(copyright.png);}

当然,IEIEIEIE6不支持属性选择器,我恨IE 6……要我说,我们就只为那些支持标准的浏览器开发这些增强的设计,比如那些支持属性选择器的。IEIEIEIE6不支持属性选择器,我恨IE 6……要我说,我们就只为那些支持标准的浏览器开发这些增强的设计,比如那些支持属性选择器的。

延伸阅读:为网页添加hCard微格式

更多精彩内容其他人还在看

Opera中国的WEB标准课程

网页制作Webjx文章简介:在这篇文章里,我要向大家介绍我和其他很多人花费数月时间开发的一个课程——Web标准课程,该课程旨在向大家提供Web设计和开发的坚实基础,无论读者是谁,此教程完全免费、可访问,并且不需要预备知识。当然,我主要还
收藏 0 赞 0 分享

CSS样式表渐进增强的基本概念

网页制作Webjx文章简介:如果你挠着头想弄清楚优雅降级和渐进增强的区别,我告诉你,这是视角问题。优雅降级和渐进增强都考虑网站在各种设备的各种浏览器上如何良好运转。两者区别的关键在于它们各自关注的焦点,以及这种关注对工作流程的影响
收藏 0 赞 0 分享

简单介绍Web Developer插件制作网页

网页制作Webjx文章简介:Firefox浏览器是一个良好支持W3C标准的开放源代码的浏览器,拥有Linux/Windows/Mac版本。因为Firefox浏览器良好支持W3C标准,所以使用Firefox来调试网页是非常好的。 Firefox浏览器是
收藏 0 赞 0 分享

CSS布局带来的巨大影响:CSS display属性值

网页制作Webjx文章简介:网页元素应用上那些与表格相关的display属性值后,能够模仿出与表格相同的特性。我将会在该文中给大家演示这种方法给CSS布局带来的巨大影响。 应原书编辑要求,先在文章顶部给出链接:《Everything You
收藏 0 赞 0 分享

用div css模拟表格对角线

这只是探讨一种CSS模拟表格对角线的用法,实际在工作中可能觉得这样做有点小题大作,这不是本主题讨论的重点。如果对此深以为然的朋友,请一笑过之 首先声明: 这只是探讨一种CSS模拟表格对角线的
收藏 0 赞 0 分享

IE Firefox在css中的差别 (部分)

1、单位问题 问题:任何距离的数值ie可以不加单位,ff必须要求写单位(0除外) 解决:写全单位如padding:0px; 2、水平居中 问题:div里的内容,ie默认为center,而ff默认left 解决:mairgin:0px auto; 3、高度问题
收藏 0 赞 0 分享

不用js可以实现信息提示效果

[code] <style> body { font:verdena; font-size:14px; color:#000 } h1{ font:verdena; font-size:22px; color:#000 } h2{ font:verdena;
收藏 0 赞 0 分享

CSS解决未知高度的垂直水平居中自适应问题

今天有人问起,晚上试着写出来,供参考; 以下代码兼容主流浏览器IE6、IE7、Firefox、Opera。 从最简单的开始………… 一、如何让一个DIV水平居中? 这个简单不作过多说明! [code] <st
收藏 0 赞 0 分享

CSS cursor 属性 -- 鼠标指针样式效果

取值: [ [<uri> ,]* [ auto | crosshair | default | pointer | move | e-resize | ne-resize | nw-resize | n-resize | se-resize | sw-resize |
收藏 0 赞 0 分享

css 简单区别ie6,ie7,firefox的写法

同一样式里可以这样 [code] margin:17px; FF +margin:17px; IE6 IE7 _margin:17px; IE6 [/code] 按这个顺序,刚好区分开三个浏览器
收藏 0 赞 0 分享
查看更多