HTML 属性:rel

rel 属性定义了所链接的资源与当前文档的关系,在 <a><area><link> 元素上有效。支持的值取决于拥有该属性的元素。

关系的类型是由 rel 属性的值给出的,如果存在的话,它的值必须是一组无序的、唯一的、用空格隔开的关键字。与不表达语义的 class 名称不同,rel 属性必须使用对机器和人类都有语义的标记。目前关于 rel 属性的可能值的注册表是 IANA 链接关系注册表HTML 现行标准和 microformats wiki 中可自由编辑的 existing-rel-values 页面(根据现行标准的建议)。如果使用一个不存在于上述三个来源之一的 rel 属性,一些 HTML 验证器(如 W3C Markup Validation Service)会产生一个警告。

下表列出了一些最重要的现有关键词。在一个以空格分隔的值内的每个关键词在该值内都应该是唯一的。

rel 描述 <link> <a><area> <form>
alternate 当前文档的替代描述。 链接 链接 不允许
author 当前文档或文章的作者。 链接 链接 不允许
bookmark 到最近祖先章节的永久链接。 不允许 链接 不允许
canonical 当前文档的首要 URL。 链接 不允许 不允许
dns-prefetch (en-US) 告知浏览器为目标资源的来源预先执行 DNS 解析。 外部资源 不允许 不允许
external 引用的文档与当前的文档不属于同一个站点。 不允许 注解 注解
help 链接到上下文相关的帮助。 链接 链接 链接
icon 代表当前文档的图标。 外部资源 不允许 不允许
license 表示当前文档的主要内容由被引用文件描述的版权许可所涵盖。 链接 链接 链接
manifest (en-US) Web 应用清单 链接 不允许 不允许
me (en-US) 表示当前文档代表拥有链接内容的人。 链接 链接 不允许
modulepreload (en-US) 告知浏览器预先获取该脚本,并将其存储在文档的模块映射中,以便稍后评估。也可以一同获取该模块的依赖关系。 外部资源 不允许 不允许
next 表示当前文档是一个系列的一部分,被引用的文档是该系列中的下一个文档。 链接 链接 链接
nofollow 表示当前文档的原作者或出版商不认可被引用的文件。 不允许 注解 注解
noopener (en-US) 创建一个顶级浏览上下文。如果该超链接一开始就会创建其中之一,则该浏览上下文不是一个辅助浏览上下文(即有一个适当的 target 属性值)。 不允许 不允许 注解
noreferrer 不会包含 Referer 标头。和 noopener 效果类似。 不允许 注解 注解
opener 如果超链接会创建一个非辅助浏览上下文的顶级浏览上下文(即以“_blank”作为 target 属性值),则创建一个辅助浏览上下文。 不允许 注解 注解
pingback 给出处理当前文档 pingback 的 pingback 服务器的地址。 外部资源 不允许 不允许
preconnect 指定用户代理应预先连接到目标资源的来源。 外部资源 不允许 不允许
prefetch 指定用户代理应预先获取并缓存目标资源,因为后续的导航可能需要它。 外部资源 不允许 不允许
preload 指定用户代理必须根据 as 属性给出的潜在目的地(以及与相应目的地相关的优先级),为当前导航预先获取和缓存目标资源。 外部资源 不允许 不允许
prerender (en-US) 指定用户代理应预先获取目标资源,并以有助于在未来提供更快的响应的方式处理它。 外部资源 不允许 不允许
prev 表示当前文档是系列的一部分,被引用的文档是该系列中的上一个文档。 链接 链接 链接
search 给出一个资源的链接,可以用来搜索当前文件及其相关页面。 链接 链接 链接
stylesheet 导入样式表。 外部资源 不允许 不允许
tag 给出一个适用于当前文档的标签(由给定地址识别)。 不允许 链接 链接

rel 属性与 <link><a><area><form> 元素有关,但有些值只与这些元素的子集有关。像所有的 HTML 关键字属性值一样,这些值是不区分大小写的。

rel 属性没有默认值。如果该属性被省略,或者该属性中没有一个值被支持,那么除了两者之间有一个超链接之外,文档与目标资源没有特别的关系。在这种情况下,在 <link><form> 元素上,如果 rel 属性不存在,没有关键词,或者如果不是上述一个或多个空格分隔的关键词,那么该元素就不会创建任何链接。<a><area> 仍将创建链接,但没有定义关系。

alternate

表示当前文档的另一种方式。对 <link><a><area> 有效,其含义取决于其他属性的值。

  • <link> 上使用 stylesheet 关键字,会创建一个替代样式表
    html
    <!-- 一个永久样式表 -->
    <link rel="stylesheet" href="default.css" />
    <!-- 替代样式表 -->
    <link
      rel="alternate stylesheet"
      href="highcontrast.css"
      title="High contrast" />
    
  • hreflang 属性与文档所使用语言不同时,表示该页面的一个翻译。
  • type 属性值为 "application/rss+xml""application/atom+xml" 会创建一个 syndication feed 的参照链接。
    html
    <link
      rel="alternate"
      type="application/atom+xml"
      href="posts.xml"
      title="Blog" />
    
  • 否则,它将创建一个超链接,引用当前文档的另一种表述,其性质由 hreflangtype 属性赋予。
    • 如果一起给出 hreflangalternate,并且 hreflang 的值与当前文档的语言不同,则表明引用的文档是一个翻译。
    • 如果一起给出 typealternate,它表示被引用的文件是一种替代格式(如 PDF)。
    • hreflangtype 属性可以与 alternate 一同给出。
    html
    <link
      rel="alternate"
      href="/fr/html/print"
      hreflang="fr"
      type="text/html"
      media="print"
      title="French HTML (for printing)" />
    <link
      rel="alternate"
      href="/fr/pdf"
      hreflang="fr"
      type="application/pdf"
      title="French PDF" />
    
author

表示被引用的文档提供了关于当前文档或文章作者的进一步信息。与 <link><a><area> 元素有关。

<a><area> 元素表示链接的文档(或 mailto:)提供了最近的祖先 <article> 元素的作者信息,如果无 article 元素就是整个文档的作者信息。

<link> 元素代表了整个文档的作者信息。

备注: 由于历史原因,废弃的属性值 rev="made" 被视为 rel="author"

bookmark

<a><area> 元素的 rel 属性值相关。如果有的话,给最近的祖先 <article> 元素提供一个固定链接。如果没有祖先 <article> 元素,则给出链接元素与之联系最紧密的部分的固定链接。

canonical

<link> 元素有效,它定义了当前文档的首选 URL,这有助于搜索引擎减少重复内容。

dns-prefetch

<body><head> 元素内与 <link> 元素相关。它告诉浏览器为目标资源的来源预先执行 DNS 解析。对于用户可能需要的资源来说,它有助于减少延迟,从而提高用户访问资源时的性能,因为浏览器会预先对指定资源的来源进行 DNS 解析。参见资源提示中描述的 dns-prefetch

external

<form><a><area> 元素相关,它表示引用的文档不是当前网站的一部分。这可以与属性选择器一起使用,使外部链接的样式向用户表明他们将离开当前网站。

help

<form><link><a><area> 元素相关,help 关键字表示链接到的内容提供上下文敏感的帮助,为定义超链接的元素的父元素及其子元素提供信息。当在 <link> 中使用时,针对整个文档。当与 <a><area> 一起包含并支持这种使用方法时,默认的 cursor 将是 help 而不是 pointer

icon

<link> 元素有效,链接的资源代表了当前文档的图标,这是一种在用户界面上代表页面资源的方法。

icon 值最常见的用途是网站图标:

html
<link rel="icon" href="favicon.ico" />

如果有多个 <link rel="icon">,浏览器会使用它们的 mediatypesizes 属性来选择最合适的图标。如果几个图标同样合适,则使用最后一个。如果后来发现最合适的图标不合适,例如使用了不支持的格式,浏览器就会继续选择下一个最合适的,以此类推。

备注: 在 Firefox 83 之前,crossorigin属性不支持 rel="icon",而 Chrome 也仍有一个未解决的问题

备注: 苹果的 iOS 系统不使用这种链接类型,也不像其他移动浏览器那样使用 sizes 属性,来选择网页夹或启动占位符的网页图标。相反,它分别使用非标准的 apple-touch-iconapple-touch-starttup-image

备注: shortcut 链接类型经常出现在 icon 之前,但这种链接类型是不符合规定的,该类型会被忽略,且网站作者不得再使用它

license

<a><area><form><link> 元素上有效,license 值表示该超链接指向描述许可信息的文件;当前文件的主要内容被引用文件描述的版权许可所覆盖。如果不在 <head> 元素内,标准并不区分适用于文档特定部分的超链接还是适用于整个文档的超链接。只有页面上的数据可以表明这一点。

html
<link rel="license" href="#license" />

备注: 虽然同义词 copyright 也是可以识别的,但它是不正确的,必须避免使用。

manifest

代表 Web 应用清单。需要使用 CORS 协议进行跨源获取。

modulepreload

对于提高性能很有用,并且与文档中的 <link> 元素相关,设置 rel="modulepreload" 告诉浏览器预先获取脚本(和依赖关系)并存储在文档的模块映射中,以便以后评估。 modulepreload 链接可以确保网络抓取时,模块映射中的模块已经准备好(但没有评估),然后才一定需要它。参见 modulepreload (en-US)

next

<form><link><a><area> 元素相关,next 值表示当前文档是一个系列的一部分,引用文档是该系列的下一个文档。当包含在 <link> 中时,浏览器可能会假定将要获取那个文档,并将其作为一个资源提示。

nofollow

<form><a><area> 元素相关, nofollow 关键字告诉搜索引擎蜘蛛忽略链接关系。nofollow 关系可能表明当前文档的所有者并不认可被引用的文档。它经常被搜索引擎优化者包括在内,假装他们的链接农场不是垃圾页面。

noopener

<form><a><area> 元素相关,如果超链接一开始就会创建其中之一(即有一个适当的 target 属性值),则会创建一个顶级浏览环境,而不是一个辅助浏览环境。换句话说,它使链接的行为如同 window.opener是空的,并且 target="_parent" 被设置。

这与 opener 具有的含义相反。

noreferrer

<form><a><area> 元素相关,包括这个值使得 referrer 未知(不会包含 Referer 标头),并创建一个顶级的浏览上下文,就像 noopener 也被设置一样。

opener

如果超链接会创建一个非辅助浏览上下文的顶级浏览上下文(即以“_blank”作为 target 属性值),则创建一个辅助浏览上下文。与 noopener 作用相反。

pingback

给出处理当前文档的 pingback 的 pingback 服务器地址。详见 Pingback 规范

preconnect

向浏览器提供提示,建议它提前打开与链接网站的连接,而不透露任何私人信息或下载任何内容,以便在跟踪链接时能更快地获取链接内容。

prefetch

指定用户代理应预先获取并缓存目标资源,因为后续导航可能需要该资源。参见链接预取以了解详细信息

preload

指定用户代理必须根据 as 属性给出的潜在目的地(以及与相应目的地相关的优先级),为当前导航预先获取和缓存目标资源。参见 preload 值的页面。

prerender

指定用户代理应抢先获取目标资源,并以有助于在未来提供更快的响应的方式对其进行处理,例如,获取其子资源或执行一些渲染。

prev

next 关键字类似,与 <form><link><a><area> 元素相关,prev 值表示当前文档是一个系列的一部分,而链接引用该系列中的一个先前文档就是被引用的文档。

备注:同义词 previous 并不正确,不应被使用。

<form><link><a><area> 元素相关,search 关键字表示该超链接引用一个文档,其界面是专门为在当前文档、站点和相关资源中搜索而设计的,提供一个可以用来搜索的资源链接。

如果 type 属性被设置为 application/opensearchdescription+xml,则该资源是一个 OpenSearch (en-US) 插件,可以很容易地添加到一些浏览器(如 Firefox 或 Internet Explorer)的界面中。

stylesheet

<link> 元素有效,它导入一个外部资源作为样式表使用。text/css 的样式表不需要 type 属性,因为这是该属性的默认值。如果它不是 text/css 类型的样式表,最好是声明这个类型。

虽然这个属性将链接定义为一个样式表,但与其他属性的交互以及 rel 值中的其他关键术语会影响样式表是否被下载和/或使用。

当与 alternate 关键字一起使用时,它定义了一个替代的样式表。在这种情况下,包括一个非空的 title

如果媒体与 media 属性的值不匹配,外部样式表将不会被使用,甚至不会下载。

需要使用 CORS 协议进行跨源获取。

tag

<a><area> 元素有效,它给出了一个适用于当前文档的标签(由给定地址标识)。标签值表示该链接指向一个描述适用于其所在文档的标签的文档。这种链接类型不是指标签云中的标签,因为这些标签适用于一组页面,而 rel 属性的 tag 值是针对单个文档。

非标准值

apple-touch-icon

指定 iOS 设备上的网络应用的图标。

规范

Specification
HTML Standard
# linkTypes
HTML Standard
# attr-hyperlink-rel

浏览器兼容性

html.elements.link.rel

BCD tables only load in the browser

html.elements.a.rel

BCD tables only load in the browser

html.elements.area.rel

BCD tables only load in the browser

参见