1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
268
269
270
271
272
273
274
275
276
277
278
279
280
281
282
283
284
285
286
287
288
289
290
291
292
293
294
295
296
297
298
299
300
301
302
303
304
305
306
307
308
309
310
311
312
313
314
315
316
317
318
319
320
321
322
323
324
325
326
327
328
329
330
331
332
333
334
335
336
|
---
title: <a>
slug: Web/HTML/Element/a
tags:
- Element
- HTML
- HTML text-level semantics
- Reference
- Web
- 元素
translation_of: Web/HTML/Element/a
---
<div>{{HTMLRef}}</div>
<p><span class="seoSummary"><strong>HTML <code><a></code> 元素</strong>(或称锚元素)可以创建通向其他网页、文件、同一页面内的位置、电子邮件地址或任何其他 URL 的超链接。</span></p>
<div>{{EmbedInteractiveExample("pages/tabbed/a.html")}}</div>
<table class="properties">
<tbody>
<tr>
<th scope="row"><dfn><a href="/en-US/docs/HTML/Content_categories" title="HTML/Content_categories">内容分类</a></dfn></th>
<td>流内容、文字内容、交互内容、可触摸内容。</td>
</tr>
<tr>
<th scope="row"><dfn>允许的内容 </dfn></th>
<td>可见的内容(Transparent),包含流内容(不包括交互式内容)或文字内容(phrasing content)。</td>
</tr>
<tr>
<th scope="row"><dfn>标签省略</dfn></th>
<td>{{no_tag_omission}}</td>
</tr>
<tr>
<th scope="row"><dfn>允许的父元素</dfn></th>
<td>接受短语内容的任何元素或接受流内容的任何元素,但始终不接受 <a> 元素(根据对称的逻辑原理,如果 <a> 标记作为父元素,不能具有交互内容,则相同的 <a> 内容不能具有 <a> 标记作为其父元素)。</td>
</tr>
<tr>
<th scope="row">Permitted ARIA roles</th>
<td>{{ARIARole("button")}}, {{ARIARole("checkbox")}}, {{ARIARole("menuitem")}}, {{ARIARole("menuitemcheckbox")}}, {{ARIARole("menuitemradio")}}, {{ARIARole("option")}}, {{ARIARole("radio")}}, {{ARIARole("switch")}}, {{ARIARole("tab")}}, {{ARIARole("treeitem")}}</td>
</tr>
<tr>
<th scope="row"><dfn>DOM 接口</dfn></th>
<td>{{domxref("HTMLAnchorElement")}}</td>
</tr>
</tbody>
</table>
<h2 id="属性">属性</h2>
<p>该元素的属性包含<a href="/zh-CN/docs/HTML/Global_attributes">全局属性</a>。</p>
<dl>
<dt>{{htmlattrdef("download")}} {{HTMLVersionInline(5)}}</dt>
<dd>此属性指示浏览器下载 URL 而不是导航到它,因此将提示用户将其保存为本地文件。如果属性有一个值,那么此值将在下载保存过程中作为预填充的文件名(如果用户需要,仍然可以更改文件名)。此属性对允许的值没有限制,但是 <code>/</code> 和 <code>\</code> 会被转换为下划线。大多数文件系统限制了文件名中的标点符号,故此,浏览器将相应地调整建议的文件名。
<div class="note"><strong>注意:</strong>
<ul>
<li>此属性仅适用于<a href="/zh-CN/docs/Web/Security/Same-origin_policy">同源 URL</a>。</li>
<li>尽管 HTTP URL 需要位于同一源中,但是可以使用 <a href="/zh-CN/docs/Web/API/URL.createObjectURL"><code>blob:</code> URL</a> 和 <a href="/zh-CN/docs/Web/HTTP/Basics_of_HTTP/Data_URIs"><code>data:</code> URL</a> ,以方便用户下载使用 JavaScript 生成的内容(例如使用在线绘图 Web 应用程序创建的照片)。</li>
<li>如果 HTTP 头中的 <a href="/zh-CN/docs/Web/HTTP/Headers/Content-Disposition">Content-Disposition</a> 属性赋予了一个不同于此属性的文件名,HTTP 头属性优先于此属性。</li>
<li>如果 HTTP 头属性 <code>Content-Disposition</code> 被设置为inline(即 <code>Content-Disposition='inline'</code>),那么 Firefox 优先考虑 HTTP 头 <code>Content-Disposition</code>download 属性。</li>
</ul>
</div>
</dd>
<dt>{{htmlattrdef("href")}}</dt>
<dd>包含超链接指向的 URL 或 URL 片段。</dd>
<dd>URL 片段是哈希标记(#)前面的名称,哈希标记指定当前文档中的内部目标位置(HTML 元素的 ID)。URL 不限于基于 Web(HTTP)的文档,也可以使用浏览器支持的任何协议。例如,在大多数浏览器中正常工作的<a class="external external-icon" href="https://en.wikipedia.org/wiki/File_URI_scheme"><code>file:</code></a>、ftp:和mailto:。
<div class="note">
<p><strong>注意:</strong> 可以使用 <code>href="#top"</code> 或者 <code>href="#"</code> 链接返回到页面顶部。<a class="external" href="http://www.whatwg.org/specs/web-apps/current-work/multipage/history.html#scroll-to-fragid">这种行为是 HTML5 的特性</a>。</p>
</div>
</dd>
<dt>{{htmlattrdef("hreflang")}}</dt>
<dd>该属性用于指定链接文档的人类语言。其仅提供建议,并没有内置的功能。hreflang 允许的值取决于HTML5 <a class="external" href="http://www.ietf.org/rfc/bcp/bcp47.txt" title="http://www.ietf.org/rfc/bcp/bcp47.txt">BCP47</a>。</dd>
<dt>{{htmlattrdef("ping")}}</dt>
<dd>包含一个以空格分隔的url列表,当跟随超链接时,将由浏览器(在后台)发送带有正文 PING 的 POST 请求。通常用于跟踪。</dd>
<dd>
</dd>
<dt>{{htmlattrdef("referrerpolicy")}} {{experimental_inline}}</dt>
<dd>表明在获取URL时发送哪个提交者(referrer):
<ul>
<li><code>"no-referrer"</code> 表示 <code>Referer:</code> 头将不会被发送。</li>
<li><code>"no-referrer-when-downgrade"</code> 表示当从使用HTTPS的页面导航到不使用 TLS(HTTPS)的来源 时不会发送 <code>Referer:</code> 头。如果没有指定策略,这将是用户代理的默认行为。</li>
<li><code>"origin"</code> 表示 referrer将会是页面的来源,大致为这样的组合:主机和端口(不包含具体的路径和参数的信息)。</li>
<li>"origin-when-cross-origin" 表示导航到其它源将会限制为这种组合:主机 + 端口,而导航到相同的源将会只包含 referrer的路径。</li>
<li><code>'strict-origin-when-cross-origin'</code></li>
<li><code>"unsafe-url"</code> 表示 referrer将会包含源和路径(domain + path)(但是不包含密码或用户名的片段)。这种情况是不安全的,因为它可能会将安全的URLs数据泄露给不安全的源。</li>
</ul>
</dd>
</dl>
<dl>
<dt>{{htmlattrdef("rel")}}</dt>
<dd>该属性指定了目标对象到链接对象的关系。该值是空格分隔的<a href="/zh-CN/docs/Web/HTML/Link_types">列表类型值</a>。</dd>
<dt>{{htmlattrdef("target")}}</dt>
<dd>该属性指定在何处显示链接的资源。 取值为标签(tab),窗口(window),或框架(iframe)等浏览上下文的名称或其他关键词。以下关键字具有特殊的意义:
<ul>
<li><code>_self</code>: 当前页面加载,即当前的响应到同一HTML 4 frame(或HTML5浏览上下文)。此值是默认的,如果没有指定属性的话。</li>
<li><code>_blank</code>: 新窗口打开,即到一个新的未命名的HTML4窗口或HTML5浏览器上下文</li>
<li><code>_parent</code>: 加载响应到当前框架的HTML4父框架或当前的HTML5浏览上下文的父浏览上下文。如果没有parent框架或者浏览上下文,此选项的行为方式与 <code>_self</code> 相同。</li>
<li><code>_top</code>: IHTML4中:加载的响应成完整的,原来的窗口,取消所有其它frame。 HTML5中:加载响应进入顶层浏览上下文(即,浏览上下文,它是当前的一个的祖先,并且没有parent)。如果没有parent框架或者浏览上下文,此选项的行为方式相同_self</li>
</ul>
</dd>
<dd>
<div class="note">
<p><strong>注意:</strong>在 <code><a></code> 元素上使用 <code>target="_blank"</code> 隐式提供了与使用 <code><a href="/zh-CN/docs/Web/HTML/Link_types/noopener">rel="noopener"</a></code> 相同的 <code>rel</code> 行为,即不会设置 <code>window.opener</code>。
</div>
</dd>
<dd>
<div class="note">
<p><strong>Note:</strong> Linking to another page using <code>target="_blank"</code> will run the new page on the same process as your page. If the new page is executing expensive JS, your page's performance may suffer. To avoid this use <code>rel=noopener</code>.</p>
</div>
</dd>
<dt>{{htmlattrdef("type")}}</dt>
<dd>该属性指定在一个 {{Glossary("MIME type")}} 链接目标的形式的媒体类型。其仅提供建议,并没有内置的功能。</dd>
<dt>
<h3 id="过时的">过时的</h3>
</dt>
<dt>{{htmlattrdef("charset")}} {{obsoleteGeneric("inline","HTML5")}}</dt>
<dd>此属性定义链接资源的字符编码。该值是一个空格- 和/或逗号分隔的<a class="external" href="http://tools.ietf.org/html/rfc2045" style="color: rgb(102, 153, 204); text-decoration: none; padding-right: 16px; background-color: rgb(255, 255, 255); font-family: 'Lucida Grande', 'Lucida Sans Unicode', 'DejaVu Sans', Lucida, Arial, Helvetica, sans-serif; font-size: 14px; font-style: normal; font-variant: normal; font-weight: normal; letter-spacing: normal; line-height: 22px; text-align: start; text-indent: 0px; text-transform: none; white-space: normal;" title="http://tool??s.ietf.org/html/rfc2045">RFC 2045</a>中定义的字符集列表。默认值是ISO-8859-1。
<div class="note">
<p><strong>使用说明: </strong>在 HTML5 中该属性已作废,不应使用。 为了实现其效果,使用HTTP content - type header的链接资源。</p>
</div>
</dd>
<dt>{{htmlattrdef("coords")}} {{HTMLVersionInline(4)}} only, {{obsoleteGeneric("inline","HTML5")}}</dt>
<dd>对于使用对象的形状,此属性使用逗号分隔的数字列表来定义对象在页面上的坐标。</dd>
<dt>{{htmlattrdef("name")}} {{HTMLVersionInline(4)}} only, {{obsoleteGeneric("inline","HTML5")}}</dt>
<dd>该属性在页面中定义锚点的目标位置时是必须的。 <strong>name</strong> 的值类似于ID核心属性值,该属性值在文档中是唯一的且由数字字母标示符所组成的。在 HTML 4.01 规范中, <strong>id</strong> 和 <strong>name</strong> 都可以使用 <a> 元素,只要他们有相同的值。
<div class="note">
<p><strong>使用说明:</strong> 该属性在 HTML5中是过时的, 使用 <a href="/zh-CN/docs/HTML/Global_attributes#attr-id" title="HTML/Global attributes#id">全局属性 <strong>id</strong></a> 来代替。</p>
</div>
</dd>
<dt>{{htmlattrdef("rev")}} {{HTMLVersionInline(4)}} only, {{obsoleteGeneric("inline","HTML5")}}</dt>
<dd>该属性用于指定当前文档与被链接文档的关系。用于 <a> 标签的可选属性 rel 和 rev 分别表示源文档与目标文档之间正式的关系和方向。rel 属性指定从源文档到目标文档的关系,而 rev 属性则指定从目标文档到源文档的关系。这两种属性可以在 <a> 标签中同时使用。对于网页编者来说,这个属性很有用,可以通过它来查看外链的来源。</dd>
</dl>
<dl>
<dt>{{htmlattrdef("shape")}} {{HTMLVersionInline(4)}} only, {{obsoleteGeneric("inline","HTML5")}}</dt>
<dd>此属性用于定义一个可选的超链接相关的一个数字来创建图像映射区域,该属性的值是圆,默认情况下,多边形,矩形。 所述的<strong>coords</strong> 属性的格式取决于形状的值。对于圆,该值的x,y,r其中x和y为圆心像素坐标,r是像素值半径。对于矩形,该<strong>coords</strong> 属性应该是x,y,w,h。x,y值定义的矩形的左上角的位置,而w和h分别定义宽度和高度。多边形形状的值需要x1,y1,x2,y2,......值来定义coords。每对x,y定义多边形的一个点,连续点由直线接合和,最后一个点连接到第一个点。默认为形状的值需要将整个封闭区域,典型的图像,可以使用。
<div class="note"><strong>说明:</strong>建议使用 <a href="/zh-CN/docs/Web/HTML/Element/img#attr-usemap">使用 map 属性</a>在 {{HTMLElement("img")}} 元素和相关的{{HTMLElement("map")}}元素中来定义热点而不是用形状属性。</div>
</dd>
</dl>
<h2 id="示例">示例</h2>
<h3 id="链接到外部地址">链接到外部地址</h3>
<pre class="brush: html"><!-- anchor linking to external file -->
<a href="http://www.mozilla.com/">
External Link
</a>
</pre>
<h4 id="Result" name="Result">结果</h4>
<p><a class="external" href="http://www.mozilla.com/">外部链接</a></p>
<h3 id="链接到本页的某个部分">链接到本页的某个部分</h3>
<pre class="brush: html"><!-- links to element on this page with id="attr-href" -->
<a href="#属性">
Description of Same-Page Links
</a></pre>
<h4 id="结果">结果</h4>
<p><a href="#属性">相同页面链接的描述</a></p>
<h3 id="创建一个可点击的图片">创建一个可点击的图片</h3>
<p>这个小例子使用图像链接到MDN主页。主页将在新的浏览环境,这是一个新的页面或新标签中打开研究。</p>
<pre class="brush: html"><a href="https://developer.mozilla.org/en-US/">
<img src="https://mdn.mozillademos.org/files/6851/mdn_logo.png"
alt="MDN logo" />
</a>
</pre>
<h4 id="结果_2">结果</h4>
<figure>
<p>{{EmbedLiveSample("创建一个可点击的图片", "320", "64")}}</p>
</figure>
<h3 id="创建一个email链接">创建一个email链接</h3>
<p>这是常见的创建按钮或链接,将用户的电子邮件程序打开,让他们发送新邮件。这是通过使用一个mailto链接完成的。这里有一个简单的例子:</p>
<pre class="brush: html"><a href="mailto:nowhere@mozilla.org">Send email to nowhere</a>
</pre>
<p>生成这样的链接: <a href="mailto:nowhere@mozilla.org">Send email to nowhere</a>.</p>
<p>有关mailto URL方案的更多细节,比如如何包含主题,正文,或其他预定内容,参考 <a href="/zh-CN/docs/Web/Guide/HTML/Email_links">Email links</a> or {{RFC(6068)}}.</p>
<h3 id="创建电话链接">创建电话链接</h3>
<p>提供电话链接有助于用户查看连接到手机的网络文档和笔记本电脑。</p>
<pre class="brush: html"><a href="tel:+491570156">+49 157 0156</a>
</pre>
<p>更详细的语法请参考 {{RFC(3966)}}。</p>
<h3 id="使用_download_属性将_<canvas>_保存为_PNG_格式">使用 download 属性将 <code><canvas></code> 保存为 PNG 格式</h3>
<p>如果你想允许用户下载一个HTML画布,你可以创建一个下载属性和画布数据作为文件URL链接图像:</p>
<pre class="brush: js">var link = document.createElement('a');
link.innerHTML = 'download image';
link.addEventListener('click', function(ev) {
link.href = canvas.toDataURL();
link.download = "mypainting.png";
}, false);
document.body.appendChild(link);</pre>
<p>可以查看这个例子 <a href="https://jsfiddle.net/codepo8/V6ufG/2/">https://jsfiddle.net/codepo8/V6ufG/2/</a></p>
<h2 id="备注">备注</h2>
<p>html 3.2 只定义 name, href, rel, rev, 和 title 属性。</p>
<h3 id="无障碍建议">无障碍建议</h3>
<p>锚点标签常常通过将 <strong>href </strong>属性设置为 <code>"#"</code> 或 <code>"javascript:void(0)" 来创造一个能阻止页面刷新的伪按钮的方式</code>被滥用。 这些属性值会在拖动 / 复制链接时导致意外行为,在新窗口 / 新标签打开链接,加入书签以及 JavaScript 仍在下载时会出现错误或被禁用。这也会向辅助技术(如屏幕阅读器)传达不正确的语义。在这些情况下,推荐使用 {{HTMLElement("button")}} 来代替。通常情况下,您应该只将锚点用于正常的 URL 导航。</p>
<h3 id="Clicking_及_focus">Clicking 及 focus</h3>
<p>点击一个 {{HTMLElement("a")}} 标签是否会出现 focus 取决于浏览器和操作系统。</p>
<table>
<caption>点击一个 {{HTMLElement("a")}} 标签是否使其获得焦点?</caption>
<tbody>
<tr>
<td>桌面浏览器</td>
<th>Windows 8.1</th>
<th>OS X 10.9</th>
</tr>
<tr>
<th>Firefox 30.0</th>
<td style="background-color: LawnGreen;">是</td>
<td style="background-color: LawnGreen;">是</td>
</tr>
<tr>
<th>Chrome ≥39<br>
(<a href="https://code.google.com/p/chromium/issues/detail?id=388666" title="Issue 388666: Focus anchor (A) elements on mousedown">Chromium bug 388666</a>)</th>
<td style="background-color: LawnGreen;">是</td>
<td style="background-color: LawnGreen;">是</td>
</tr>
<tr>
<th>Safari 7.0.5</th>
<td style="background-color: silver;">不可用</td>
<td style="background-color: yellow;">仅当包含 <code>tabindex 属性时</code></td>
</tr>
<tr>
<th>Internet Explorer 11</th>
<td style="background-color: LawnGreen;">是</td>
<td style="background-color: silver;">不可用</td>
</tr>
<tr>
<th>Presto (Opera 12)</th>
<td style="background-color: LawnGreen;">是</td>
<td style="background-color: LawnGreen;">是</td>
</tr>
</tbody>
</table>
<table>
<caption>轻触一个 {{HTMLElement("a")}} 标签是否使其获得焦点?</caption>
<tbody>
<tr>
<td>移动浏览器</td>
<th>iOS 7.1.2</th>
<th>Android 4.4.4</th>
</tr>
<tr>
<th>Safari Mobile</th>
<td style="background-color: yellow;">仅当包含 <code>tabindex 属性时</code></td>
<td style="background-color: silver;">不可用</td>
</tr>
<tr>
<th>Chrome 35</th>
<td>未知</td>
<td style="background-color: yellow;">仅当包含 <code>tabindex 属性时</code></td>
</tr>
</tbody>
</table>
<h2 id="Specifications" name="Specifications">规范</h2>
<table class="standard-table">
<thead>
<tr>
<th scope="col">Specification</th>
<th scope="col">Status</th>
<th scope="col">Comment</th>
</tr>
</thead>
<tbody>
<tr>
<td>{{SpecName('Referrer Policy', '#referrer-policy-delivery-referrer-attribute', 'referrer attribute')}}</td>
<td>{{Spec2('Referrer Policy')}}</td>
<td>Added the <code>referrer </code>attribute.</td>
</tr>
<tr>
<td>{{SpecName('HTML WHATWG', 'text-level-semantics.html#the-a-element', '<a>')}}</td>
<td>{{Spec2('HTML WHATWG')}}</td>
<td></td>
</tr>
<tr>
<td>{{SpecName('HTML5 W3C', 'textlevel-semantics.html#the-a-element', '<a>')}}</td>
<td>{{Spec2('HTML5 W3C')}}</td>
<td></td>
</tr>
<tr>
<td>{{SpecName('HTML4.01', 'struct/links.html#h-12.2', '<a>')}}</td>
<td>{{Spec2('HTML4.01')}}</td>
<td></td>
</tr>
</tbody>
</table>
<h2 id="浏览器兼容性">浏览器兼容性</h2>
<p>{{Compat("html.elements.a")}}</p>
<h2 id="相关链接">相关链接</h2>
<ul>
<li>其它传递<a href="/zh-CN/docs/HTML/Text_level_semantics_conveying_elements" title="HTML/Text level semantics conveying elements">文本级语义</a>的元素:{{HTMLElement("abbr")}}, {{HTMLElement("em")}}, {{HTMLElement("strong")}}, {{HTMLElement("small")}}, {{HTMLElement("cite")}}, {{HTMLElement("q")}}, {{HTMLElement("dfn")}}, {{HTMLElement("time")}}, {{HTMLElement("code")}}, {{HTMLElement("var")}}, {{HTMLElement("samp")}}, {{HTMLElement("kbd")}}, {{HTMLElement("sub")}}, {{HTMLElement("sup")}}, {{HTMLElement("b")}}, {{HTMLElement("i")}}, {{HTMLElement("mark")}}, {{HTMLElement("ruby")}}, {{HTMLElement("rp")}}, {{HTMLElement("rt")}}, {{HTMLElement("bdo")}}, {{HTMLElement("span")}}, {{HTMLElement("br")}}, {{HTMLElement("wbr")}}.</li>
</ul>
|