Syntax | <a>...</a> |
---|---|
Attribute Specifications |
|
Contents | Inline elements except a |
Contained in | Block-level elements, inline elements except a and button |
The a element denotes an anchor--a hypertext link or the destination of a link. The href attribute specifies a hypertext link to another resource, such as an XHTML document or a JPEG image. Examples:
<a href="album.html">My photo
album</a>
<a href="../images/me.jpg">Picture of
me</a>
<a href="/sounds/auldlang.mid"
type="audio/midi" accesskey="a">Auld Lang Syne (5 kB
MIDI)</a>
<a href="section2.html" target="content" title="Elements of the head"
rel="next">Section 2</a>
<a href="mailto:liam@htmlhelp.com"
title="Feedback on HTML 1.0
Reference">liam@htmlhelp.com</a>
<a href="http://www.htmlhelp.com/"
target="_top">Web Design
Group</a>
<a
href="http://babel.alis.com:8080/langues/iso639.zh.htm"
charset="big5" hreflang="zh">ISO 639</a>
The value of the href attribute is the URI of the link. The type attribute can be used to specify the Internet media type of the link, allowing browsers to avoid fetching a resource that they cannot handle.
The title attribute can be used to briefly describe the contents of the link and is rendered as a "tooltip" by some visual browsers. With mailto links, some browsers use the title attribute value as a subject for the e-mail message.
The content of an a
element used as a link should be as context-free as possible. In
other words, a user should be able to pull all a elements from a document and still have an idea
what lies behind each link. Link text that contains
Click here
or simply
here
is extremely bad
form.
The target attribute is used with frames to specify in which frame the link should be rendered. If no frame with such a name exists, the link is rendered in a new window unless overridden by the user. Special frame names begin with an underscore:
In XHTML 1.0, the target attribute value is case-insensitive, so that _top and _TOP both have the same meaning. However, most browsers treat the target attribute value as case-sensitive and do not recognize _TOP as having the special meaning of _top.
The optional hreflang and charset attributes give the language and character encoding, respectively, of the link. The language should be specified according to RFC 1766; examples include en for English, en-us for American English, and ja for Japanese. Examples of character encodings include iso-8859-1, shift_jis, and utf-8.
The accesskey attribute specifies a single Unicode character as a shortcut key for following the link. Entities (e.g. é) may be used as the accesskey value.
The tabindex attribute specifies a number between 0 and 32767 to indicate the tabbing order of the element. An anchor with tabindex="0" or no tabindex attribute will be visited after any elements with a positive tabindex. Among positive tabindex values, the lower number receives focus first. In the case of a tie, the element appearing first in the XHTML document takes precedence.
The rel and rev attributes define relationships between an anchor and the linked resource. rel defines a link relationship from the current document to the linked document while rev defines a relationship in the opposite direction. For example,
<a href="foo.html"
rel="Glossary">...</a>
indicates that foo.html is a glossary for the current document while
<a href="bar.html"
rev="Subsection">...</a>
indicates that the current document is a subsection of bar.html. The value of the rel and rev attributes is a space-separated list of link types.
The name attribute defines a destination for a link. For example, a document containing
<h1><a
name="foo">my heading</a></h1>
defines a link destination named "foo" at the indicated heading. One could then use href="#foo" in an a element within the same document or href="somedoc.html#foo" from within another document.
An a element cannot contain another a element, so one must be careful that named anchors do not contain link anchors. Authors can use both the name and href attributes in a single a element to avoid this problem.
XHTML 1.0's id attribute is intended to eliminate the need for a name. The id attribute can be used with almost any element to define a link destination, so that the following could be used in place of the previous example:
<h1 id="foo">my
heading</h1>
However, browser support for id link destinations is not perfect, so a name will be needed for quite awhile. If both a name and id are specified, they must be the same.
name and id values must be unique in any document, and different values must differ by more than just the case. id values must begin with a letter in the range A-Z or a-z, and may be followed by A-Z, a-z, 0-9, hyphens, underscores, colons, or periods. When linking to a named anchor, the name is treated as case sensitive.
The shape and coords attributes of a can be used to create client-side image maps via the object element. The default shape value is rect, which defines a rectangular region using coords="left, top, right, bottom". Other shape values are
Coordinate values are relative to the top left corner of the object and may be expressed as pixels or percentages. A percentage radius value for circular regions is calculated relative to the smaller of the object's width and height. If two or more regions overlap, the earliest specified region takes precedence.
In addition to the core events common to most elements, a accepts the following event attributes for client-side scripting: