【发布时间】:2012-05-08 19:19:45
【问题描述】:
编辑:这个问题很长,包括几个我正在寻找的东西的例子。我找到了答案(见下文),即确实存在这样的事情,您可以在 schema.org 上阅读所有相关信息。
我希望能够将某些语义信息附加到同一页面上的多个不同项目。例如,我的页面有一个歌曲列表,看起来有点像:
<div class="song">
<img src="cover-art-image" />
<p>Description on image</p>
<a id="..." href="link-to-song">View song</a>
</div>
<div class="song">
...
</div>
现在,我想显示有关这些对象(在本例中为歌曲)的语义信息,因此我们在歌曲实际页面上的 <meta> 标签中包含语义数据(以及 <link rel="author" ...> 等)。
所以我想知道最好的方式是传达链接"View song" 是唯一描述语义对象(元数据和所有)。
我已经阅读了有关使用 link rel="canonical" 的信息,但据我所知,这是用于标题中,用于描述 当前页面(或者,通知搜索引擎当前页面的规范表示是什么),而我想要传达我们想要描述当前页面上显示的子对象。所以,在一个理想的世界里,我会写这样的东西:
<div class="song">
<img ... />
<p> ... </p>
<a href="link-to-song" rel="canonical">View Song</a>
</div>
来描述href(即歌曲的页面)末尾的东西是父HTML节点的规范表示。但是,rel="canonical" 的真正含义并非如此:是否已经定义了类似的东西可以做(即交流)我想要的东西?
如果不是,那么实现这种东西的最“网络友好”的方式是什么?我敢肯定,仅仅使用多个 rel="canonical" 链接不是这样做的方法(最好不要通过尝试嵌入实际上应该有用的语义数据来冒犯搜索引擎)。
我唯一能想到的就是放类似
<a href="..." rev="summary"> ... </a>
为了反映这里显示的是条目主页上内容的摘要 - 但我不认为这被解释为“限定范围”以表示“包含此链接的 DOM 节点是 . ..”。
编辑:关于如何使用它的另一个示例(如果我的意思不清楚)可能是让博客文章上的每条评论都包含这样一个链接,这将唯一标识与该特定关联的 URI邮政。在该链接之后,您会找到一个包含例如的页面。 <link rel="author"...> 评论信息、指向发表评论的帖子的链接等等。
编辑:为了更清楚我的意思,我们已经使用元数据,例如
<link rel="canonical" href="..." />
在页面的<head> 中传达关于this URI 中描述的对象(或内容)的语义数据。因此,位于<head> 中的元数据可以被认为是作用域(滥用术语)到页面级别。我想知道我们如何在页面的各个部分级别对元数据进行范围界定(因此在上面的示例中,我想在包含它们的 DOM 节点级别界定元信息)。以下不是有效的标记(出于显而易见的原因,将受到搜索引擎的惩罚),但说明了我的意思:
<html>
<head>
<link rel="canonical" href="/canonical/representation/of/this/page.html" />
</head>
<body>
<div id="item1">
<a rel="canonical" href="/canonical/representation/of/item1.html" />
<p>Some local description of item2</p>
</div>
<div id="item2">
<a rel="canonical" href="/canonical/representation/of/item2.html" />
<p>Some local description of item2</p>
</div>
</body>
</html>
那么在地址/canonical/representation/of/item1.html我们可能会找到一些语义数据(例如,Open Graph数据):
<html prefix="og: http://ogp.me/ns#">
<head>
<meta property="og:title" content="Some title" />
<meta property="og:type" content="music.song" />
<meta property="og:url" content="/canonical/representation/of/item1.html" />
</head>
<body>
<!-- User-facing content of the page -->
</body>
</html>
这种关系需要rel=... 标记的原因是,我们希望将其标记为包含有关页面特定部分的相关语义数据(而不是页面中可能指向任何地方的其他链接),并且应该紧随其后的是想要发现此类数据的程序(然后可以知道这些数据仅与链接所在的特定 DOM 节点“限定”的页面部分相关)。
【问题讨论】:
标签: html semantic-web semantic-markup rel