HTML element: Difference between revisions
Andy Dingley (talk | contribs) Undid revision 842284058 by 199.182.226.99 (talk) |
Nøkkenbuer (talk | contribs) m →longdesc attribute: uncapitalization in section title per code |
||
(9 intermediate revisions by the same user not shown) | |||
Line 1: | Line 1: | ||
{{Use American English|date=March 2018}} |
|||
{{Selfref|This article is about the [[HTML]] elements in general. For information on how to format Wikipedia entries, see [[Help:Wiki markup]] and [[Help:HTML in wikitext]].}} |
{{Selfref|This article is about the [[HTML]] elements in general. For information on how to format Wikipedia entries, see [[Help:Wiki markup]] and [[Help:HTML in wikitext]].}} |
||
{{redirect|nobr|the chemical compound NOBr|Nitrosyl bromide}} |
{{redirect|nobr|the chemical compound NOBr|Nitrosyl bromide}} |
||
{{Html series}} |
{{Html series}} |
||
An '''<abbr title="Hyper Text Markup Language">HTML</abbr> element''' is an individual component of an [[HTML]] document or [[web page]], once this has been parsed into the [[HTML Document Object Model|Document Object Model]]. HTML is composed of a [[Tree structure|tree]] of HTML [[Node (computer science)|nodes]], such as text nodes. Each node can have [[HTML attribute]]s specified. Nodes can also have content, including other nodes and text. Many HTML nodes represent [[semantics]], or meaning. For example, the < |
An '''<abbr title="Hyper Text Markup Language">HTML</abbr> element''' is an individual component of an [[HTML]] document or [[web page]], once this has been parsed into the [[HTML Document Object Model|Document Object Model]]. HTML is composed of a [[Tree structure|tree]] of HTML [[Node (computer science)|nodes]], such as text nodes. Each node can have [[HTML attribute]]s specified. Nodes can also have content, including other nodes and text. Many HTML nodes represent [[semantics]], or meaning. For example, the {{code|lang=html|code=<title>}} node represents the title of the document. |
||
==Concepts== |
==Concepts== |
||
===Document vs. DOM=== |
===Document vs. DOM=== |
||
HTML documents are delivered as "documents". |
HTML documents are delivered as "documents".{{refn|group=note|"Document" may refer interchangeably to either a file stored on a computer filesystem, usually on disk, or to a document delivered across the Web by [[HTTP]]. Such documents may equally be copies of disk files stored on the web server, or they may be generated on demand.}} These are then [[parsing|parsed]], which turns them into the [[HTML Document Object Model|Document Object Model]] (DOM) internal representation, within the web browser.{{refn|group=note|[[Document Object Model]] is now a formalized specification by the [[W3C]].<ref name="W3C Current DOM version" >{{Cite web |
||
|title=Document Object Model (DOM) Current Version |
|title=Document Object Model (DOM) Current Version |
||
|date=26 July 2016 |
|date=26 July 2016 |
||
|url=http://www.w3.org/TR/dom |
|url=http://www.w3.org/TR/dom |
||
|publisher=[[W3C]] |
|publisher=[[W3C]] |
||
}}</ref> It defines |
}}</ref> It defines {{em|an interface to}} this internal model, rather than the internal model itself. Early web browsers used their own internal representation that bore little relation to the DOM. The term "document tree" has also been applied.<ref>{{Cite web |
||
|title=Definitions – Document tree |
|title=Definitions – Document tree |
||
|section=3 Conformance: Requirements and Recommendations |
|section=3 Conformance: Requirements and Recommendations |
||
Line 19: | Line 20: | ||
|url=http://www.w3.org/TR/CSS2/conform.html#doctree |
|url=http://www.w3.org/TR/CSS2/conform.html#doctree |
||
|publisher=[[W3C]] |
|publisher=[[W3C]] |
||
}}</ref> However for the purpose here, of explaining the difference between a document of tags and a parsed model of elements, it is convenient to use the term DOM throughout. |
}}</ref> However for the purpose here, of explaining the difference between a document of tags and a parsed model of elements, it is convenient to use the term DOM throughout.}}{{refn|group=note|The term "web browser" here is used for simplicity. It does of course include other sorts of [[web user agent]], such as search engine [[web crawler]]s, automatic news-feed retrievers etc.}} |
||
Presentation by the web browser, such as screen rendering or access by JavaScript, is then performed on this internal model, not the original document. |
Presentation by the web browser, such as screen rendering or access by JavaScript, is then performed on this internal model, not the original document. |
||
Early HTML documents, and to a lesser extent today, were largely [[invalid HTML]] and riddled with [[well-formed HTML|syntax errors]]. The parsing process was also required to "fix-up" these errors, as best it could. The resultant model was often not |
Early HTML documents, and to a lesser extent today, were largely [[invalid HTML]] and riddled with [[well-formed HTML|syntax errors]]. The parsing process was also required to "fix-up" these errors, as best it could. The resultant model was often not {{em|correct}} (i.e., it did not represent what a careless coder had originally intended), but it would at least be [[Valid HTML|valid]], according to the HTML standard. A valid model was produced, no matter how bad the "[[tag soup]]" supplied had been. Only in the rarest cases would the parser abandon parsing altogether. |
||
===Elements vs. tags=== |
===Elements vs. tags=== |
||
"Elements" and "tags" are terms that are widely confused. HTML documents contain tags, but do not contain the elements. The elements are only generated |
"Elements" and "tags" are terms that are widely confused. {{citation needed span|text=HTML documents contain tags, but do not contain the elements. The elements are only generated {{em|after}} the parsing step, from these tags.|date=March 2017|reason=This has been challenged on the talk page.}} |
||
As is generally understood, the position of an element is indicated as spanning from a start tag, possibly including some child content, and is terminated by an end tag.<ref>{{Cite web |
As is generally understood, the position of an element is indicated as spanning from a start tag, possibly including some child content, and is terminated by an end tag.<ref>{{Cite web |
||
Line 35: | Line 36: | ||
|url=http://www.w3.org/TR/1999/REC-html401-19991224/intro/sgmltut.html#h-3.2.1 |
|url=http://www.w3.org/TR/1999/REC-html401-19991224/intro/sgmltut.html#h-3.2.1 |
||
|publisher=[[W3C]] |
|publisher=[[W3C]] |
||
}}</ref> This is the case for many, |
}}</ref> This is the case for many, but not all, elements within an HTML document. |
||
As HTML is based on [[SGML]],<ref>{{Cite web |
As HTML is based on [[SGML]],<ref>{{Cite web |
||
Line 49: | Line 50: | ||
|url=http://www.w3.org/TR/1999/REC-html401-19991224/sgml/dtd.html |
|url=http://www.w3.org/TR/1999/REC-html401-19991224/sgml/dtd.html |
||
|publisher=[[W3C]] |
|publisher=[[W3C]] |
||
}}</ref> |
}}</ref>{{refn|group=note|HTML 4.01 is one of a small number of well-known HTML DTDs. It is chosen here as the best illustrative example, although the same behavior applies to the other W3C-published DTDs for HTML.}} The DTD specifies which element types are possible (i.e. it defines the set of element types that go to make up HTML) and it also specifies the valid combinations in which they may appear in a document. It is part of general SGML behavior that where only one valid structure is {{em|possible}} (per the DTD), it is not generally a requirement that the document explicitly states that structure. As a simple example, the {{code|lang=html|code=<p>}} start tag indicating the start of a paragraph element should be closed by a {{code|lang=html|code=</p>}} end tag, indicating the end of the element. Also the DTD states that paragraph elements cannot be nested. The HTML document fragment: |
||
: {{code|lang=html|code=<p>Para 1 <p>Para 2 <p>Para 3 }} |
: {{code|lang=html|code=<p>Para 1 <p>Para 2 <p>Para 3 }} |
||
can thus be inferred to be equivalent to: |
can thus be inferred to be equivalent to: |
||
Line 55: | Line 56: | ||
(If one paragraph element cannot contain another, any currently open paragraph must be closed before starting another.) |
(If one paragraph element cannot contain another, any currently open paragraph must be closed before starting another.) |
||
Because of this implied behavior, based on the combination of the DTD and the individual document, it is not possible to infer elements from the document tags |
Because of this implied behavior, based on the combination of the DTD and the individual document, it is not possible to infer elements from the document tags {{em|alone}}, but only by also using an SGML or HTML aware parser, with knowledge of the DTD. |
||
===SGML vs. XML=== |
===SGML vs. XML=== |
||
SGML is complex, which has limited its widespread adoption and understanding. [[XML]] was developed as a simpler alternative. XML is similar to SGML, that can also use the DTD mechanism to specify the supported elements and their permitted combinations as document structure. XML parsing is simpler. The relation from tags to elements is always that of parsing the actual tags included in the document, without the implied closures that are part of SGML. |
SGML is complex, which has limited its widespread adoption and understanding. [[XML]] was developed as a simpler alternative. XML is similar to SGML, that can also use the DTD mechanism to specify the supported elements and their permitted combinations as document structure. XML parsing is simpler. The relation from tags to elements is always that of parsing the actual tags included in the document, without the implied closures that are part of SGML.{{refn|group=note|A macro-like feature of DTDs may still be used within XML.}} |
||
In Macros HTML can be formed as XML, either through [[XHTML]] or through [[HTML5]], the parsing of document tags as DOM elements is simplified. Once the DOM of elements is obtained, behavior beyond that point (i.e. screen rendering) is identical.{{refn|One minor point is that XML, even after the DOM interface, is case-sensitive.<ref>{{Cite web |
In Macros HTML can be formed as XML, either through [[XHTML]] or through [[HTML5]], the parsing of document tags as DOM elements is simplified. Once the DOM of elements is obtained, behavior beyond that point (i.e. screen rendering) is identical.{{refn|group=note|One minor point is that XML, even after the DOM interface, is case-sensitive.<ref>{{Cite web |
||
|title=§1.3. XHTML and the HTML DOM |
|title=§1.3. XHTML and the HTML DOM |
||
|work=Document Object Model (DOM) Level 2 HTML Specification |
|work=Document Object Model (DOM) Level 2 HTML Specification |
||
Line 67: | Line 68: | ||
|url=http://www.w3.org/TR/2003/REC-DOM-Level-2-HTML-20030109/html.html#ID-5353782642 |
|url=http://www.w3.org/TR/2003/REC-DOM-Level-2-HTML-20030109/html.html#ID-5353782642 |
||
|publisher=[[W3C]] |
|publisher=[[W3C]] |
||
}}</ref> |
}}</ref>}} |
||
===<code>%block;</code> vs. box=== |
===<code>%block;</code> vs. box=== |
||
Line 79: | Line 80: | ||
|url=http://www.w3.org/TR/1999/REC-html401-19991224/struct/global.html#h-7.5.3 |
|url=http://www.w3.org/TR/1999/REC-html401-19991224/struct/global.html#h-7.5.3 |
||
|publisher=[[W3C]] |
|publisher=[[W3C]] |
||
}}</ref> This is used to define their nesting behavior: block-level elements cannot be placed into an inline context. |
}}</ref> This is used to define their nesting behavior: block-level elements cannot be placed into an inline context.{{refn|group=note|However, see {{code|lang=html|code=<object>}} for the inevitable exception.}} This behavior cannot be changed; it is fixed in the DTD. Block and inline elements have the appropriate and different CSS behaviors attached to them by default,<ref name="W3C, HTML 4.01, block and inline" /> including the relevance of the box model for particular element types. |
||
Note though that this CSS behavior can, and frequently is, changed from the default. Lists with {{code|lang=html|code=<ul><li> ...}} are <code>%block;</code> elements and are presented as block elements by default. However, it is quite common to set these with CSS to display as an inline list.<ref>{{Cite web |
Note though that this CSS behavior can, and frequently is, changed from the default. Lists with {{code|lang=html|code=<ul><li> ...}} are <code>%block;</code> elements and are presented as block elements by default. However, it is quite common to set these with CSS to display as an inline list.<ref>{{Cite web |
||
Line 102: | Line 103: | ||
</math> |
</math> |
||
}} |
}} |
||
In the HTML syntax, most elements are written with a start tag and an end tag, with the content in between. An '''HTML tag''' is composed of the name of the element, surrounded by [[angle brackets]]. An end tag also has a slash after the opening angle bracket, to distinguish it from the start tag. For example, a paragraph, which is represented by the < |
In the HTML syntax, most elements are written with a start tag and an end tag, with the content in between. An '''HTML tag''' is composed of the name of the element, surrounded by [[angle brackets]]. An end tag also has a slash after the opening angle bracket, to distinguish it from the start tag. For example, a paragraph, which is represented by the {{code|lang=html|code=<p>}} element, would be written as: |
||
<syntaxhighlight lang="html4strict"> |
<syntaxhighlight lang="html4strict"> |
||
<p>In the HTML syntax, most elements are written ...</p> |
<p>In the HTML syntax, most elements are written ...</p> |
||
</syntaxhighlight> |
</syntaxhighlight> |
||
However, not all of these elements |
However, not all of these elements {{em|require}} the end tag, or even the start tag, to be present. <!--Examples will be given throughout the article when I get around to it. —Ms2ger--> Some elements, the so-called ''void elements'' or {{Anchor|Empty element}} ''empty elements'', do not have an end tag. A typical example is the {{code|lang=html|code=<br />}} element, which represents a significant [[Hard return|line break]], such as in a poem or an address. A void element's behavior is predefined, and it cannot contain any content or other elements. For example, an address would be written as: |
||
<syntaxhighlight lang="html4strict"> |
<syntaxhighlight lang="html4strict"> |
||
<p>P. Sherman<br>42 Wallaby Way<br>Sydney</p> |
<p>P. Sherman<br>42 Wallaby Way<br>Sydney</p> |
||
</syntaxhighlight> |
</syntaxhighlight> |
||
When using an [[XHTML]] [[Document Type Declaration|DTD]], it is required to open and close the element with a single tag. To specify that it is a void element, a <code>/</code> is included at the |
When using an [[XHTML]] [[Document Type Declaration|DTD]], it is required to open and close the element with a single tag. To specify that it is a void element, a <code>/</code> is included at the {{strong|end}} of the tag (not to be confused with the <code>/</code> at the {{strong|beginning}} of a closing tag). |
||
<syntaxhighlight lang="html4strict"> |
<syntaxhighlight lang="html4strict"> |
||
<p>P. Sherman<br />42 Wallaby Way<br />Sydney</p> |
<p>P. Sherman<br />42 Wallaby Way<br />Sydney</p> |
||
</syntaxhighlight> |
</syntaxhighlight> |
||
[[HTML attributes]] are specified inside the start tag. For example, the |
[[HTML attributes]] are specified inside the start tag. For example, the {{code|lang=html|code=<abbr>}} element, which represents an [[abbreviation]], expects a {{code|lang=html|code=<title>}} attribute within its opening tag. This would be written as: |
||
<syntaxhighlight lang="html4strict"> |
<syntaxhighlight lang="html4strict"> |
||
<abbr title="abbreviation">abbr.</abbr> |
<abbr title="abbreviation">abbr.</abbr> |
||
Line 123: | Line 124: | ||
'''Void elements''' only have a start tag, which contains any [[HTML attributes]]. They may not contain any children, such as text or other elements. Often they are place holders for elements which reference external files, such as the image ({{code|lang=html|code=<img />}}) element. The attributes included in the element will then point to the external file in question. |
'''Void elements''' only have a start tag, which contains any [[HTML attributes]]. They may not contain any children, such as text or other elements. Often they are place holders for elements which reference external files, such as the image ({{code|lang=html|code=<img />}}) element. The attributes included in the element will then point to the external file in question. |
||
Another example of a void element is the {{code|lang=html|code=<link />}} element, for which the syntax is |
Another example of a void element is the {{code|lang=html|code=<link />}} element, for which the syntax is: |
||
<syntaxhighlight lang="html4strict"> |
<syntaxhighlight lang="html4strict"> |
||
<link rel="stylesheet" href="fancy.css" type="text/css"> |
<link rel="stylesheet" href="fancy.css" type="text/css"> |
||
Line 164: | Line 165: | ||
In 1998, [[XML]] (a simplified form of SGML) introduced mechanisms to allow anyone to develop their own elements and incorporate them in [[XHTML]] documents, for use with XML-aware user agents.<ref>[[#XML10|XML 1.0]] (The ability to produce additional elements is part of the ''eXtensibility'' in the acronym.)</ref> |
In 1998, [[XML]] (a simplified form of SGML) introduced mechanisms to allow anyone to develop their own elements and incorporate them in [[XHTML]] documents, for use with XML-aware user agents.<ref>[[#XML10|XML 1.0]] (The ability to produce additional elements is part of the ''eXtensibility'' in the acronym.)</ref> |
||
Subsequently, HTML 4.01 was rewritten in an [[XML]]-compatible form, [[#XHTML10|XHTML 1.0]] (''eXtensible HTML''). The elements in each are identical, and in most cases valid [[XHTML]] 1.0 documents will be valid or nearly valid HTML 4.01 documents. This article mainly focuses on real HTML, unless noted otherwise; however, it remains applicable to [[XHTML]]. |
Subsequently, HTML 4.01 was rewritten in an [[XML]]-compatible form, [[#XHTML10|XHTML 1.0]] (''eXtensible HTML''). The elements in each are identical, and in most cases valid [[XHTML]] 1.0 documents will be valid or nearly valid HTML 4.01 documents. This article mainly focuses on real HTML, unless noted otherwise; however, it remains applicable to [[XHTML]]. See [[HTML#SGML-based versus XML-based HTML|HTML]] for a discussion of the minor differences between the two. |
||
===Element status=== |
===Element status=== |
||
Line 202: | Line 203: | ||
Historically, user agents did not always support these features. In the 1990s, as a stop-gap, presentational elements (like {{code|lang=html|code=<b>}} and {{code|lang=html|code=<i>}}) were added to HTML, at the cost of creating problems for interoperability and user accessibility. This is now regarded as outmoded and has been superseded by style sheet-based design; most presentational elements are now deprecated.<ref name="HTML401-141">[[#HTML401|HTML 4.01]] §14.1</ref> |
Historically, user agents did not always support these features. In the 1990s, as a stop-gap, presentational elements (like {{code|lang=html|code=<b>}} and {{code|lang=html|code=<i>}}) were added to HTML, at the cost of creating problems for interoperability and user accessibility. This is now regarded as outmoded and has been superseded by style sheet-based design; most presentational elements are now deprecated.<ref name="HTML401-141">[[#HTML401|HTML 4.01]] §14.1</ref> |
||
External image files are incorporated with the < |
External image files are incorporated with the {{code|lang=html|code=<img>}} or {{code|lang=html|code=<object>}} elements. (With [[XHTML]], the [[SVG]] language can also be used to write graphics within the document, though linking to external SVG files is generally simpler.)<ref name="SVG11-23">{{cite web |
||
| author = Ferraiolo, J. Fujisawa, J, and Jackson, D (editors) |
| author = Ferraiolo, J. Fujisawa, J, and Jackson, D (editors) |
||
| title = Scalable Vector Graphics (SVG) 1.1 Specification, §2.3 ''Options for using SVG in Web pages'' |
| title = Scalable Vector Graphics (SVG) 1.1 Specification, §2.3 ''Options for using SVG in Web pages'' |
||
Line 212: | Line 213: | ||
An HTML document can also be extended through the use of scripts to provide additional behaviors beyond the abilities of HTML hyperlinks and forms. |
An HTML document can also be extended through the use of scripts to provide additional behaviors beyond the abilities of HTML hyperlinks and forms. |
||
The elements < |
The elements {{code|lang=html|code=<style>}} and {{code|lang=html|code=<script>}}, with related [[HTML attributes]], provide reference points in HTML markup for links to style sheets and scripts. They can also contain instructions directly. |
||
* In the document head, < |
* In the document head, {{code|lang=html|code=<script>}} and {{code|lang=html|code=<style>}} may either link to shared external documents, or contain embedded instructions. (The {{code|lang=html|code=<link>}} element can also be used to link style sheets.) |
||
* The ''style attribute'' is valid in most document body elements for inclusion of ''inline style'' instructions. |
* The ''style attribute'' is valid in most document body elements for inclusion of ''inline style'' instructions. |
||
* ''Event-handling attributes'', which provide links to scripts, are optional in most elements. |
* ''Event-handling attributes'', which provide links to scripts, are optional in most elements. |
||
* < |
* {{code|lang=html|code=<script>}} can occur at any point in the document body. |
||
* For user agents which do not operate scripts, the < |
* For user agents which do not operate scripts, the {{code|lang=html|code=<noscript>}} element provides alternative content where appropriate; however, it can only be used as a block-level element. |
||
==Document structure elements== |
==Document structure elements== |
||
Line 239: | Line 240: | ||
{{Anchor|base|base_tag}}{{XMLElement|base|Base|...|end=no}} |
{{Anchor|base|base_tag}}{{XMLElement|base|Base|...|end=no}} |
||
:Specifies a '''base |
:Specifies a '''base URL''' for all relative <code>href</code> and other links in the document. Must appear before any element that refers to an external resource. HTML permits only one {{code|lang=html|code=<base>}} element for each document. The {{code|lang=html|code=<base>}} element has [[HTML attributes]], but no contents. |
||
:A development version of |
:A development version of <code>BASE</code> is mentioned in ''[[#HTMLTAGS|HTML Tags]]''; '''standardized''' in [[#HTML20|HTML 2.0]]; still current. |
||
{{Anchor|basefont|basefont_tag}}{{XMLElement|basefont|Base Font|...|deprecated=1|end=no}} |
{{Anchor|basefont|basefont_tag}}{{XMLElement|basefont|Base Font|...|deprecated=1|end=no}} |
||
:Specifies a base font size, typeface, and color for the document. Used together with < |
:Specifies a base font size, typeface, and color for the document. Used together with {{code|lang=html|code=<font>}} elements. [[Deprecation|Deprecated]] in favor of [[Style sheet (web development)|style sheets]]. |
||
:'''Standardized''' in [[#HTML32|HTML 3.2]]; '''deprecated''' in [[#HTML401|HTML 4.0 Transitional]]; '''invalid''' in [[#HTML401|HTML 4.0 Strict]]. |
:'''Standardized''' in [[#HTML32|HTML 3.2]]; '''deprecated''' in [[#HTML401|HTML 4.0 Transitional]]; '''invalid''' in [[#HTML401|HTML 4.0 Strict]]. |
||
{{Anchor|isindex|isindex_tag}}{{XMLElement|isindex|Index|...|end=no|deprecated=1}} |
{{Anchor|isindex|isindex_tag}}{{XMLElement|isindex|Index|...|end=no|deprecated=1}} |
||
: |
:{{code|lang=html|code=<isindex>}} could either appear in the document head or in the body, but only once in a document. See [[Fieldset|Forms]]. |
||
{{Anchor|link|link_tag}}{{XMLElement|link|Link|...|end=no}} |
{{Anchor|link|link_tag}}{{XMLElement|link|Link|...|end=no}} |
||
Line 254: | Line 255: | ||
:A less-common, but important, usage is to supply navigation hints consistently through use of [[microformat]]s. Several common relationships are defined, that may be exposed to users through the browser interface rather than directly in the web page. |
:A less-common, but important, usage is to supply navigation hints consistently through use of [[microformat]]s. Several common relationships are defined, that may be exposed to users through the browser interface rather than directly in the web page. |
||
::{{code|lang=html|code=<link rel="next" href="url">}} |
::{{code|lang=html|code=<link rel="next" href="url">}} |
||
:A document's < |
:A document's {{code|lang=html|code=<head>}} element may contain any number of {{code|lang=html|code=<link>}} elements. The {{code|lang=html|code=<link>}} element has [[HTML attributes]], but no contents. |
||
: |
:<code>LINK</code> existed in ''[[#HTMLDRAFT12|HTML Internet Draft 1.2]]'', and was '''standardized''' in [[#HTML20|HTML 2.0]]; still current. |
||
{{Anchor|meta|meta_tag}}[[Meta element|{{XMLElement|meta|Meta|...|end=no}}]] |
{{Anchor|meta|meta_tag}}[[Meta element|{{XMLElement|meta|Meta|...|end=no}}]] |
||
{{Main|Meta element}} |
{{Main|Meta element}} |
||
:Can be used to specify additional [[metadata]] about a document, such as its author, publication date, expiration date, page description, keywords, or other information not provided through the other header elements and [[HTML attributes]]. Because of their generic nature, |
:Can be used to specify additional [[metadata]] about a document, such as its author, publication date, expiration date, page description, keywords, or other information not provided through the other header elements and [[HTML attributes]]. Because of their generic nature, {{code|lang=html|code=<meta>}} elements specify associative [[Associative array|key-value pairs]]. In general, a meta element conveys hidden information about the document. Several meta tags can be used, all of which should be nested in the head element. The specific purpose of each {{code|lang=html|code=<meta>}} element is defined by its attributes. |
||
:In one form, < |
:In one form, {{code|lang=html|code=<meta>}} elements can specify [[HTTP]] headers which should be sent by a [[web server]] before the actual content. For example, {{code|lang=html|code=<meta http-equiv="foo" content="bar">}} specifies that the page should be served with an HTTP header called <code>foo</code> that has a value <code>bar</code>. |
||
:In the general form, a |
:In the general form, a {{code|lang=html|code=<meta>}} element specifies <code>name</code> and associated <code>content</code> [[HTML attributes]] describing aspects of the HTML page. To prevent possible ambiguity, an optional third attribute, <code>scheme</code>, may be supplied to specify a semantic framework that defines the meaning of the key and its value. For example, in {{code|lang=html|code=<meta name="foo" content="bar" scheme="DC">}} the {{code|lang=html|code=<meta>}} element identifies itself as containing the <code>foo</code> element, with a value of <code>bar</code>, from the DC or [[Dublin Core]] [[Resource Description Framework|resource description framework]]. |
||
:'''Standardized''' in [[#HTML20|HTML 2.0]]; still current. |
:'''Standardized''' in [[#HTML20|HTML 2.0]]; still current. |
||
{{Anchor|object}}{{XMLElement|object|Object|...}} |
{{Anchor|object}}{{XMLElement|object|Object|...}} |
||
:Used for including generic objects within the document header. Though rarely used within a < |
:Used for including generic objects within the document header. Though rarely used within a {{code|lang=html|code=<head>}} element, it could potentially be used to extract foreign data and associate it with the current document. |
||
:'''Standardized''' in [[#HTML401|HTML 4.0]]; still current. |
:'''Standardized''' in [[#HTML401|HTML 4.0]]; still current. |
||
Line 284: | Line 285: | ||
:* It may become the default file-name when saving the page. |
:* It may become the default file-name when saving the page. |
||
:* [[Web search engine]]s' [[web crawler]]s may pay particular attention to the words used in the title. |
:* [[Web search engine]]s' [[web crawler]]s may pay particular attention to the words used in the title. |
||
:The |
:The {{code|lang=html|code=<title>}} element must not contain other elements, only text. Only one {{code|lang=html|code=<title>}} element is permitted in a document. |
||
: |
:{{code|lang=html|code=<title>}} existed in ''[[#HTMLTAGS|HTML Tags]]'', and was '''standardized''' in [[#HTML20|HTML 2.0]]; still current. |
||
==Document body elements== |
==Document body elements== |
||
Line 319: | Line 320: | ||
{{Anchor|h6|h6_tag}}{{XMLElement|h6|6. Level Headline|...}} |
{{Anchor|h6|h6_tag}}{{XMLElement|h6|6. Level Headline|...}} |
||
:Section headings at different levels. <code>h1</code> delimits the highest-level heading, <code>h2</code> the next level down (sub-section), <code>h3</code> for a level below that, and so on to <code>h6</code>. They are sometimes referred to collectively as <code>h''n''</code> tags, ''n'' meaning any of the available heading levels. |
:Section headings at different levels. <code>h1</code> delimits the highest-level heading, <code>h2</code> the next level down (sub-section), <code>h3</code> for a level below that, and so on to <code>h6</code>. They are sometimes referred to collectively as <code>h''n''</code> tags, ''n'' meaning any of the available heading levels. |
||
:Most visual browsers show headings as large bold text by default, though this can be overridden with [[Cascading Style Sheets|CSS]]. Heading elements are not intended merely for creating large or bold |
:Most visual browsers show headings as large bold text by default, though this can be overridden with [[Cascading Style Sheets|CSS]]. Heading elements are not intended merely for creating large or bold text – in fact, they should {{em|not}} be used for explicitly styling text. Rather, they describe the document’s structure and organization. Some programs use them to generate outlines and tables of contents. |
||
:Headings existed in ''[[#HTMLTAGS|HTML Tags]]'', and were '''standardized''' in [[#HTML20|HTML 2.0]]; still current. |
:Headings existed in ''[[#HTMLTAGS|HTML Tags]]'', and were '''standardized''' in [[#HTML20|HTML 2.0]]; still current. |
||
Line 375: | Line 376: | ||
{{Anchor|blockquote|blockquote_tag}}{{XMLElement|blockquote|BlockQuotation|...}} |
{{Anchor|blockquote|blockquote_tag}}{{XMLElement|blockquote|BlockQuotation|...}} |
||
:A [[blockquote|block level quotation]], for when the quotation includes block level elements, e.g. paragraphs. The <code>cite</code> attribute may give the source, and must be a fully qualified [[Uniform Resource Identifier]]. |
:A [[blockquote|block level quotation]], for when the quotation includes block level elements, e.g. paragraphs. The <code>cite</code> attribute may give the source, and must be a fully qualified [[Uniform Resource Identifier]]. |
||
:The default presentation of block quotations in visual browsers is usually to indent them from both margins. This has led to the element being unnecessarily used just to indent paragraphs, regardless of semantics. For quotations not containing block level elements see the quote ([[#q|< |
:The default presentation of block quotations in visual browsers is usually to indent them from both margins. This has led to the element being unnecessarily used just to indent paragraphs, regardless of semantics. For quotations not containing block level elements see the quote ([[#q|{{code|lang=html|code=<q>}}]]) element. |
||
:<code>BLOCKQUOTE</code> existed in ''[[#HTMLDRAFT12|HTML Internet Draft 1.2]]'', and was '''standardized''' in [[#HTML20|HTML 2.0]]; still current. See [[blockquote element]] for more information. |
:<code>BLOCKQUOTE</code> existed in ''[[#HTMLDRAFT12|HTML Internet Draft 1.2]]'', and was '''standardized''' in [[#HTML20|HTML 2.0]]; still current. See [[blockquote element]] for more information. |
||
Line 432: | Line 433: | ||
{{Anchor|pre|pre_tag}}{{XMLElement|pre|PreFormattedText|...}} |
{{Anchor|pre|pre_tag}}{{XMLElement|pre|PreFormattedText|...}} |
||
:''Pre-formatted'' text. Text within this element is typically displayed in a [[non-proportional font]] exactly as it is laid out in the file (see [[ASCII art]]). Whereas browsers ignore [[Whitespace (computer science)|white-space]] for other HTML elements, in <code>pre</code>, white-space should be rendered as authored. (With the CSS properties: {{code|lang=css|code= |
:''Pre-formatted'' text. Text within this element is typically displayed in a [[non-proportional font]] exactly as it is laid out in the file (see [[ASCII art]]). Whereas browsers ignore [[Whitespace (computer science)|white-space]] for other HTML elements, in <code>pre</code>, white-space should be rendered as authored. (With the CSS properties: {{code|lang=css|code={white-space: pre; font-family: monospace;}<nowiki />}}, other elements can be presented in the same way.) This element can contain any inline element except: image (<code>IMG</code>), object (<code>OBJECT</code>), big font size (<code>BIG</code>), small font size (<code>SMALL</code>), superscript (<code>SUP</code>), and subscript (<code>SUB</code>). |
||
:<code>PRE</code> existed in ''[[#HTMLDRAFT12|HTML Internet Draft 1.2]]'', and was '''standardized''' in [[#HTML20|HTML 2.0]]; still current. |
:<code>PRE</code> existed in ''[[#HTMLDRAFT12|HTML Internet Draft 1.2]]'', and was '''standardized''' in [[#HTML20|HTML 2.0]]; still current. |
||
{{anchor|section|section_tag}}{{XMLElement|section|Section|...}} |
{{anchor|section|section_tag}}{{XMLElement|section|Section|...}} |
||
:Used for generic sections of a document. This is different from < |
:Used for generic sections of a document. This is different from {{code|lang=html|code=<div>}} in that it is only used to contain sections of a page, which the W3C defines as a group of content with a similar theme. |
||
:'''Standardized''' in [[#HTML5|HTML5]]. |
:'''Standardized''' in [[#HTML5|HTML5]]. |
||
{{Anchor|script|script_tag}}{{XMLElement|script|Script|...}} |
{{Anchor|script|script_tag}}{{XMLElement|script|Script|...}} |
||
:Places a script in the document. Also usable in the head and in inline contexts. |
:Places a script in the document. Also usable in the head and in inline contexts. |
||
::Note: <code>SCRIPT</code> is not itself either a block or inline element; by itself it should not display at all, but it can contain instructions to dynamically generate either both block or inline content. |
::{{strong|Note:}} <code>SCRIPT</code> is not itself either a block or inline element; by itself it should not display at all, but it can contain instructions to dynamically generate either both block or inline content. |
||
:'''Standardized''' in [[#HTML32|HTML 3.2]]; still current. |
:'''Standardized''' in [[#HTML32|HTML 3.2]]; still current. |
||
===Inline elements=== |
===Inline elements=== |
||
Inline elements cannot be placed directly inside the < |
Inline elements cannot be placed directly inside the {{code|lang=html|code=<body>}} element; they must be wholly nested within block-level elements.<ref>{{citation|url=http://www.w3.org/TR/html401/struct/global.html#h-7.5.1 |title=HTML 4.01 |publisher=W3.org |date= |accessdate=2012-03-26}}</ref> |
||
====Anchor==== |
====Anchor==== |
||
Line 452: | Line 453: | ||
{{Anchor|a|a_tag}}{{XMLElement|a|Anchor|...}} |
{{Anchor|a|a_tag}}{{XMLElement|a|Anchor|...}} |
||
:An anchor element is called an anchor because web designers can use it to "anchor" a URL to some text on a web page. When users view the web page in a browser, they can click the text to activate the link and visit the page whose URL is in the link.<ref>''HTML 4 for dummies'', 5th edition, 2005, |
:An anchor element is called an anchor because web designers can use it to "anchor" a URL to some text on a web page. When users view the web page in a browser, they can click the text to activate the link and visit the page whose URL is in the link.<ref>''HTML 4 for dummies'', 5th edition, 2005, |
||
By Ed Tittel, Mary C. Burmeister, p. 96.</ref> |
|||
:In HTML, an '''anchor''' can be either the origin (the [[anchor text]]) or the ''target'' (destination) end of a '''[[hyperlink]]'''. |
:In HTML, an '''anchor''' can be either the origin (the [[anchor text]]) or the ''target'' (destination) end of a '''[[hyperlink]]'''. |
||
:With the attribute <code>href</code>,<ref>{{cite web|url=http://www.w3.org/Provider/ServerWriter.html|title=ServerWriter -- /Provider|website=www.w3.org}}</ref> the anchor becomes a hyperlink to either another part of the document or another resource (e.g. a webpage) using an external [[Uniform Resource Locator|URL]]. Alternatively (and sometimes concurrently), with the <code>name</code> or <code>id</code> [[HTML attributes]] set, the element becomes a '''target'''. A [[Uniform Resource Locator]] can link to this target via a [[fragment identifier]]. In HTML5, any element can now be made into a target by using the <code>id</code> attribute,<ref>{{cite web|url=http://w3.org/tr/html5/index.html#attributes-1|title=HTML 5.2|website=w3.org}}</ref> so using {{code|lang=html|code=<a name="foo">...</a>}} is not necessary, although this way of adding anchors continues to work. |
:With the attribute <code>href</code>,<ref>{{cite web|url=http://www.w3.org/Provider/ServerWriter.html|title=ServerWriter -- /Provider|website=www.w3.org}}</ref> the anchor becomes a hyperlink to either another part of the document or another resource (e.g. a webpage) using an external [[Uniform Resource Locator|URL]]. Alternatively (and sometimes concurrently), with the <code>name</code> or <code>id</code> [[HTML attributes]] set, the element becomes a '''target'''. A [[Uniform Resource Locator]] can link to this target via a [[fragment identifier]]. In HTML5, any element can now be made into a target by using the <code>id</code> attribute,<ref>{{cite web|url=http://w3.org/tr/html5/index.html#attributes-1|title=HTML 5.2|website=w3.org}}</ref> so using {{code|lang=html|code=<a name="foo">...</a>}} is not necessary, although this way of adding anchors continues to work. |
||
Line 463: | Line 464: | ||
: or with a link on the same page like: |
: or with a link on the same page like: |
||
:: {{code|lang=html|code=<a href="#contents">contents, above</a>}} |
:: {{code|lang=html|code=<a href="#contents">contents, above</a>}} |
||
:The attribute < |
:The attribute {{code|lang=html|code=<title>}} may be set to give brief information about the link: |
||
::{{code|lang=html|code=<a href="URL" title="additional information">link text</a>}} |
::{{code|lang=html|code=<a href="URL" title="additional information">link text</a>}} |
||
:In most graphical browsers, when the cursor hovers over a link, the cursor changes into a hand with an extended index finger and the < |
:In most graphical browsers, when the cursor hovers over a link, the cursor changes into a hand with an extended index finger and the {{code|lang=html|code=<title>}} is displayed in a [[tooltip]] or in some other manner. Some browsers render [[alt attribute|alt text]] the same way, although this is not what the specification calls for. |
||
:<code>A</code> existed in ''[[#HTMLTAGS|HTML Tags]]'', and was '''standardized''' in [[#HTML20|HTML 2.0]]; still current. |
:<code>A</code> existed in ''[[#HTMLTAGS|HTML Tags]]'', and was '''standardized''' in [[#HTML20|HTML 2.0]]; still current. |
||
Line 478: | Line 479: | ||
{{Anchor|acronym|acronym_tag}}{{XMLElement|acronym|Acronym|...|deprecated=1}} |
{{Anchor|acronym|acronym_tag}}{{XMLElement|acronym|Acronym|...|deprecated=1}} |
||
:Similar to the < |
:Similar to the {{code|lang=html|code=<abbr>}} element, but marks an [[acronym]]: |
||
::{{code|lang=html|code=<acronym title="Hyper-Text Mark-up Language">HTML</acronym>}} |
::{{code|lang=html|code=<acronym title="Hyper-Text Mark-up Language">HTML</acronym>}} |
||
:'''Standardized''' in [[#HTML401|HTML 4.0]]; still current, '''not supported''' in [[#HTML5|HTML5]]. |
:'''Standardized''' in [[#HTML401|HTML 4.0]]; still current, '''not supported''' in [[#HTML5|HTML5]]. |
||
Line 503: | Line 504: | ||
{{Anchor|kbd|kbd_tag}}{{XMLElement|kbd|Keyboard|...}} |
{{Anchor|kbd|kbd_tag}}{{XMLElement|kbd|Keyboard|...}} |
||
:Keyboard |
:Keyboard – text to be entered by the user (<kbd>kbd example</kbd>). |
||
:<code>KBD</code> existed in ''[[#HTMLDRAFT12|HTML Internet Draft 1.2]]'', and was '''standardized''' in [[#HTML20|HTML 2.0]]; still current. |
:<code>KBD</code> existed in ''[[#HTMLDRAFT12|HTML Internet Draft 1.2]]'', and was '''standardized''' in [[#HTML20|HTML 2.0]]; still current. |
||
{{Anchor|samp|samp_tag}}{{XMLElement|samp|Sample|...}} |
{{Anchor|samp|samp_tag}}{{XMLElement|samp|Sample|...}} |
||
:Sample output |
:Sample output – from a program or script: (<samp>samp example</samp>). |
||
:<code>SAMP</code> existed in ''[[#HTMLDRAFT12|HTML Internet Draft 1.2]]'', and was '''standardized''' in [[#HTML20|HTML 2.0]]; still current. |
:<code>SAMP</code> existed in ''[[#HTMLDRAFT12|HTML Internet Draft 1.2]]'', and was '''standardized''' in [[#HTML20|HTML 2.0]]; still current. |
||
Line 518: | Line 519: | ||
{{Anchor|b|b_tag}}{{XMLElement|b|Bold|...}} <!-- not deprecated in [[HTML 4.01]]; not included in [[XHTML 2.0]] which is in draft stage; now a semantic element in [[HTML5]] --> |
{{Anchor|b|b_tag}}{{XMLElement|b|Bold|...}} <!-- not deprecated in [[HTML 4.01]]; not included in [[XHTML 2.0]] which is in draft stage; now a semantic element in [[HTML5]] --> |
||
:In [[HTML 4]], set font to '''boldface''' where possible. Equivalent CSS: {{code|lang=css|code={font-weight: bold<nowiki |
:In [[HTML 4]], set font to '''boldface''' where possible. Equivalent CSS: {{code|lang=css|code={font-weight: bold}<nowiki />}}. {{code|lang=html|code='''...'''}} usually has the same effect in visual browsers, as well as having more semantic meaning, under [[HTML 4.01]]. |
||
:In [[HTML5]], however, {{code|lang=html|code=<b>}} has its own meaning, distinct from that of {{code|lang=html|code=<strong>}}. It denotes "text to which attention is being drawn for utilitarian purposes without conveying any extra importance and with no implication of an alternate voice or mood."<ref name="html5-b-element">{{citation|url=http://developers.whatwg.org/text-level-semantics.html#the-b-element |title=4.6 Text-level semantics — The b element |publisher=Developers.whatwg.org |date= |accessdate=2012-03-26}}</ref> |
:In [[HTML5]], however, {{code|lang=html|code=<b>}} has its own meaning, distinct from that of {{code|lang=html|code=<strong>}}. It denotes "text to which attention is being drawn for utilitarian purposes without conveying any extra importance and with no implication of an alternate voice or mood."<ref name="html5-b-element">{{citation|url=http://developers.whatwg.org/text-level-semantics.html#the-b-element |title=4.6 Text-level semantics — The b element |publisher=Developers.whatwg.org |date= |accessdate=2012-03-26}}</ref> |
||
:<code>B</code> existed in ''[[#HTMLDRAFT12|HTML Internet Draft 1.2]]'', and was '''standardized''' in [[#HTML20|HTML 2.0]]; still current. |
:<code>B</code> existed in ''[[#HTMLDRAFT12|HTML Internet Draft 1.2]]'', and was '''standardized''' in [[#HTML20|HTML 2.0]]; still current. |
||
Line 533: | Line 534: | ||
{{Anchor|small|small_tag}}{{XMLElement|small|Small|...}} |
{{Anchor|small|small_tag}}{{XMLElement|small|Small|...}} |
||
:In [[HTML 4]], decreased font size (<small>smaller</small> text). Equivalent CSS: |
:In [[HTML 4]], decreased font size (<small>smaller</small> text). Equivalent CSS: {{code|lang=css|code={font-size: smaller}<nowiki />}} |
||
:In [[HTML5]], the {{code|lang=html|code=<small>}} element denotes "side comments such as small print."<ref name="html5-small-element">{{citation|url=http://developers.whatwg.org/text-level-semantics.html#the-small-element |title=4.6 Text-level semantics — The small element |publisher=Developers.whatwg.org |date= |accessdate=2012-03-26}}</ref> |
:In [[HTML5]], the {{code|lang=html|code=<small>}} element denotes "side comments such as small print."<ref name="html5-small-element">{{citation|url=http://developers.whatwg.org/text-level-semantics.html#the-small-element |title=4.6 Text-level semantics — The small element |publisher=Developers.whatwg.org |date= |accessdate=2012-03-26}}</ref> |
||
:'''Standardized''' in [[#HTML32|HTML 3.2]]; still current. |
:'''Standardized''' in [[#HTML32|HTML 3.2]]; still current. |
||
Line 566: | Line 567: | ||
:Equivalent CSS for font attributes: |
:Equivalent CSS for font attributes: |
||
:*<code class="mw-highlight" dir="rtl"><span class="p"><</span><span class="nt">font</span> <span class="na">size</span><span class="o">=</span><span class="s">"<var>N</var>"</span><span class="p">></span></code> corresponds to <code class="mw-highlight" dir="ltr"><span class="p">{</span><span class="nb">font-size</span><span class="o" style="color: #666;">:</span> <span class="nb"><var>Y</var><var>units</var></span><span class="p">}</span></code> (the HTML specification does not define the relationship between size <var>N</var> and unit-size <var>Y</var>, nor does it define a unit). |
:*<code class="mw-highlight" dir="rtl"><span class="p"><</span><span class="nt">font</span> <span class="na">size</span><span class="o">=</span><span class="s">"<var>N</var>"</span><span class="p">></span></code> corresponds to <code class="mw-highlight" dir="ltr"><span class="p">{</span><span class="nb">font-size</span><span class="o" style="color: #666;">:</span> <span class="nb"><var>Y</var><var>units</var></span><span class="p">}</span></code> (the HTML specification does not define the relationship between size <var>N</var> and unit-size <var>Y</var>, nor does it define a unit). |
||
:*{{code|lang=html|code=<font color="red">}} corresponds to |
:*{{code|lang=html|code=<font color="red">}} corresponds to {{code|lang=css|code={color: red}<nowiki />}} |
||
:*{{code|lang=html|code=<font face="Courier">}} corresponds to |
:*{{code|lang=html|code=<font face="Courier">}} corresponds to {{code|lang=css|code={font-family: "Courier"}<nowiki />}} |
||
:'''Standardized''' in [[#HTML32|HTML 3.2]]; '''deprecated''' in [[#HTML401|HTML 4.0 Transitional]]; '''invalid''' in [[#HTML401|HTML 4.0 Strict]]. Not part of HTML5. |
:'''Standardized''' in [[#HTML32|HTML 3.2]]; '''deprecated''' in [[#HTML401|HTML 4.0 Transitional]]; '''invalid''' in [[#HTML401|HTML 4.0 Strict]]. Not part of HTML5. |
||
Line 604: | Line 605: | ||
{{Anchor|ins|ins_tag}}{{XMLElement|ins|Inserted|...}} |
{{Anchor|ins|ins_tag}}{{XMLElement|ins|Inserted|...}} |
||
:Inserted text. Often used to mark up replacement text for < |
:Inserted text. Often used to mark up replacement text for {{code|lang=html|code=<del>}}'d text. Typically rendered [[underline]]d: <ins>Inserted text.</ins> |
||
:'''Standardized''' in [[#HTML401|HTML 4.0]]; still current. |
:'''Standardized''' in [[#HTML401|HTML 4.0]]; still current. |
||
::Note, both < |
::Note, both {{code|lang=html|code=<ins>}} and {{code|lang=html|code=<del>}} elements may also be used as block elements: containing other block and inline elements. However, these elements must still remain wholly within their parent element to maintain a well-formed HTML document. For example, deleting text from the middle of one paragraph across several other paragraphs and ending in a final paragraph would need to use three separate {{code|lang=html|code=<del>}} elements. Two {{code|lang=html|code=<del>}} elements would be required as inline element to indicate the deletion of text in the first and last paragraphs, and a third, used as a block element, to indicate the deletion in the intervening paragraphs. |
||
{{Anchor|mark|mark_tag}}{{XMLElement|mark|Mark|...}} |
{{Anchor|mark|mark_tag}}{{XMLElement|mark|Mark|...}} |
||
Line 614: | Line 615: | ||
{{Anchor|q|q_tag}}{{XMLElement|q|Quote|...}} |
{{Anchor|q|q_tag}}{{XMLElement|q|Quote|...}} |
||
:An inline quotation (for block level quotation see [[#blockquote|< |
:An inline quotation (for block level quotation see [[#blockquote|{{code|lang=html|code=<blockquote>}}]]). Quote elements may be nested. |
||
:< |
:{{code|lang=html|code=<q>}} {{em|should}} automatically generate quotation marks in conjunction with style sheets. Practical concerns due to browser non-compliance may force authors to find workarounds. |
||
:The <code>cite</code> |
:The <code>cite</code> attribute gives the source, and must be a fully qualified [[Uniform Resource Identifier|URI]]. |
||
:'''Standardized''' in [[#HTML401|HTML 4.0]]; still current. |
:'''Standardized''' in [[#HTML401|HTML 4.0]]; still current. |
||
::Note: Lengthy inline quotations may be displayed as indented blocks (as <code>block-quote</code>) using style sheets. For example, with a suitable CSS rule associated with <code>q.lengthy</code>: |
::{{strong|Note:}} Lengthy inline quotations may be displayed as indented blocks (as <code>block-quote</code>) using style sheets. For example, with a suitable CSS rule associated with <code>q.lengthy</code>: |
||
:::{{code|lang=html|code=<q class="lengthy">}}An inline quotation of significant length ( |
:::{{code|lang=html|code=<q class="lengthy">}}An inline quotation of significant length (e.g., 25 words) goes here.{{code|lang=html|code=</q>}} |
||
{{Anchor|rb|rb_tag}}{{XMLElement|rb|Ruby Annotation Base|...|}} |
{{Anchor|rb|rb_tag}}{{XMLElement|rb|Ruby Annotation Base|...|}} |
||
Line 643: | Line 644: | ||
{{Anchor|script|script_tag}}{{XMLElement|script|Script|...}} |
{{Anchor|script|script_tag}}{{XMLElement|script|Script|...}} |
||
:Places a [[scripting language|script]] in the document. Also usable in the head and in block contexts. |
:Places a [[scripting language|script]] in the document. Also usable in the head and in block contexts. |
||
::Note: < |
::{{strong|Note:}} {{code|lang=html|code=<script>}} is not itself either a block or inline element; by itself it should not display at all, but it can contain instructions to dynamically generate either both block or inline content. |
||
:'''Standardized''' in [[#HTML32|HTML 3.2]]; still current. |
:'''Standardized''' in [[#HTML32|HTML 3.2]]; still current. |
||
{{Anchor|sub|sub_tag}}{{XMLElement|sub|Subscript|...}} and {{Anchor|sup|sup_tag}}{{XMLElement|sup|Superscript|...}} |
{{Anchor|sub|sub_tag}}{{XMLElement|sub|Subscript|...}} and {{Anchor|sup|sup_tag}}{{XMLElement|sup|Superscript|...}} |
||
:Mark <sub>[[subscript]]</sub> or <sup>[[superscript]]</sup> text. (Equivalent CSS: |
:Mark <sub>[[subscript]]</sub> or <sup>[[superscript]]</sup> text. (Equivalent CSS: {{code|lang=css|code={vertical-align: sub}<nowiki />}} and {{code|lang=css|code={vertical-align: super}<nowiki />}} respectively.) |
||
:Both were proposed in the [[#HTML30|HTML 3.0 Drafts]]; '''Standardized''' in [[#HTML32|HTML 3.2]]; still current. |
:Both were proposed in the [[#HTML30|HTML 3.0 Drafts]]; '''Standardized''' in [[#HTML32|HTML 3.2]]; still current. |
||
Line 665: | Line 666: | ||
{{Anchor|applet|applet_tag}}{{XMLElement|applet|Java Applet|...|deprecated=xhtml}} |
{{Anchor|applet|applet_tag}}{{XMLElement|applet|Java Applet|...|deprecated=xhtml}} |
||
:Embeds a [[Java applet]] in the page. Deprecated in favor of < |
:Embeds a [[Java applet]] in the page. Deprecated in favor of {{code|lang=html|code=<object>}}, as it could only be used with Java applets, and had accessibility limitations. |
||
:'''Standardized''' in [[#HTML32|HTML 3.2]]; '''deprecated''' in [[#HTML401|HTML 4.0 Transitional]]; '''invalid''' in [[#HTML401|HTML 4.0 Strict]]. As of 2011, still widely used as the implementations of the replacing < |
:'''Standardized''' in [[#HTML32|HTML 3.2]]; '''deprecated''' in [[#HTML401|HTML 4.0 Transitional]]; '''invalid''' in [[#HTML401|HTML 4.0 Strict]]. As of 2011, still widely used as the implementations of the replacing {{code|lang=html|code=<object>}} are not consistent between different browsers. |
||
{{Anchor|area|area_tag}}{{XMLElement|area|Area|...|end=no}} |
{{Anchor|area|area_tag}}{{XMLElement|area|Area|...|end=no}} |
||
:Specifies a [[Focus (computing)|focusable]] area in a < |
:Specifies a [[Focus (computing)|focusable]] area in a {{code|lang=html|code=<map>}}. |
||
:'''Standardized''' in [[#HTML32|HTML 3.2]]; still current. |
:'''Standardized''' in [[#HTML32|HTML 3.2]]; still current. |
||
Line 681: | Line 682: | ||
;{{Anchor|embed}}{{XMLElement|embed|Embed|...|}} |
;{{Anchor|embed}}{{XMLElement|embed|Embed|...|}} |
||
:Inserts a non-standard object (like applet) or external content (typically non-HTML) into the document. Deprecated in HTML 4 in favor of |
:Inserts a non-standard object (like applet) or external content (typically non-HTML) into the document. Deprecated in HTML 4 in favor of {{code|lang=html|code=<object>}}, but then was added back into the HTML5 specification<ref>[http://webdesign.about.com/od/htmltags/p/bltags_embed.htm Jennifer Kyrnin ]{{code|lang=html|code=<embed>}}</ref><ref>[https://www.w3schools.com/tags/tag_embed.asp W3Schools] about {{code|lang=html|code=<embed>}}</ref> |
||
{{Anchor|img|img_tag}}{{XMLElement|img|Image|...|end=no}} |
{{Anchor|img|img_tag}}{{XMLElement|img|Image|...|end=no}} |
||
:Used by visual user agents to insert an [[image]] in the document. The <code>src</code> attribute specifies the image URL. The required [[Alt attribute|<code>alt</code> attribute]] provides alternative text in case the image cannot be displayed.<ref>The alt attribute's text cannot be styled with markup; as a result, other methods of alternative text presentation, such as [[Fahrner Image Replacement]], have been devised to accommodate situations in which the coder wishes styled text to be displayed if images are disabled in a user's browser.</ref> (Though <code>alt</code> is intended as alternative text, Microsoft [[Internet Explorer]] 7 and below render it as a [[tooltip]] if no |
:Used by visual user agents to insert an [[image]] in the document. The <code>src</code> attribute specifies the image URL. The required [[Alt attribute|<code>alt</code> attribute]] provides alternative text in case the image cannot be displayed.<ref>The alt attribute's text cannot be styled with markup; as a result, other methods of alternative text presentation, such as [[Fahrner Image Replacement]], have been devised to accommodate situations in which the coder wishes styled text to be displayed if images are disabled in a user's browser.</ref> (Though <code>alt</code> is intended as alternative text, Microsoft [[Internet Explorer]] 7 and below render it as a [[tooltip]] if no {{code|lang=html|code=<title>}} is given.<ref>{{cite web | url=http://msdn.microsoft.com/en-us/library/cc288472.aspx#access | title=What's New in Internet Explorer 8 – Accessibility and ARIA | publisher=Microsoft | work=MSDN | accessdate=2009-07-22}}</ref> [[Safari (web browser)|Safari]] and [[Google Chrome]], on the other hand, do not display the alt attribute at all.)<ref>{{citation|url=https://bugs.webkit.org/show_bug.cgi?id=5566 |title=Bug 5566 – ALT attribute value sometimes not displayed when image is missing |publisher=Bugs.webkit.org |date= |accessdate=2012-03-26}}</ref> {{code|lang=html|code=<img>}} was proposed by [[Marc Andreessen]] and implemented in the [[Mosaic (web browser)|NSCA Mosaic]] web browser.<ref>{{citation|url=http://1997.webhistory.org/www.lists/www-talk.1993q1/0182.html |title=WWW-Talk Jan-Mar 1993: proposed new tag: IMG |publisher=1997.webhistory.org |date= |accessdate=2012-03-26}}</ref> |
||
: |
:<code>IMG</code> existed in ''[[#HTMLDRAFT12|HTML Internet Draft 1.2]]'', and was '''standardized''' in [[#HTML20|HTML 2.0]]; still current. |
||
{{Anchor|map|map_tag}}{{XMLElement|map|Image Map|...|}} |
{{Anchor|map|map_tag}}{{XMLElement|map|Image Map|...|}} |
||
Line 696: | Line 697: | ||
{{Anchor|param|param_tag}}{{XMLElement|param|Object Parameter|...|end=no}} |
{{Anchor|param|param_tag}}{{XMLElement|param|Object Parameter|...|end=no}} |
||
:Originally introduced with |
:Originally introduced with {{code|lang=html|code=<applet>}}, this element is now used with, and should only occur as a child of {{code|lang=html|code=<object>}}. It uses [[HTML attributes]] to set a parameter for the object, e.g. width, height, font, background color, etc., depending on the type of object. An object can have multiple {{code|lang=html|code=<param>}} elements. |
||
:'''Standardized''' in [[#HTML32|HTML 3.2]]; still current. |
:'''Standardized''' in [[#HTML32|HTML 3.2]]; still current. |
||
{{anchor|source|source_tag}}{{XMLElement|source|Source|...}} |
{{anchor|source|source_tag}}{{XMLElement|source|Source|...}} |
||
:Specifies different sources for audio or video. Makes use of the <code>src</code> attribute in a way similar to the < |
:Specifies different sources for audio or video. Makes use of the <code>src</code> attribute in a way similar to the {{code|lang=html|code=<video>}} and {{code|lang=html|code=<audio>}} elements. |
||
:'''Standardized''' in [[#HTML5|HTML5]]. |
:'''Standardized''' in [[#HTML5|HTML5]]. |
||
Line 719: | Line 720: | ||
{{Anchor|form|form_tag}}{{XMLElement|form|Form|...|atr={{XMLAttribute|action|Action|url|type=URL|need=required}}}} |
{{Anchor|form|form_tag}}{{XMLElement|form|Form|...|atr={{XMLAttribute|action|Action|url|type=URL|need=required}}}} |
||
:Creates a [[form (web)|form]]. The |
:Creates a [[form (web)|form]]. The {{code|lang=html|code=<form>}} element specifies and operates the overall action of a form area, using the required <code>action</code> attribute. |
||
:'''Standardized''' in [[#HTML20|HTML 2.0]]; still current. |
:'''Standardized''' in [[#HTML20|HTML 2.0]]; still current. |
||
Line 731: | Line 732: | ||
{{Anchor|fieldset|fieldset_tag}}{{XMLElement|fieldset|Fieldset|...}} |
{{Anchor|fieldset|fieldset_tag}}{{XMLElement|fieldset|Fieldset|...}} |
||
:A container for adding structure to forms. For example, a series of related controls can be grouped within a |
:A container for adding structure to forms. For example, a series of related controls can be grouped within a {{code|lang=html|code=<fieldset>}}, which can then have a {{code|lang=html|code=<legend>}} added in order to identify their function. |
||
:'''Standardized''' in [[#HTML401|HTML 4.0]]; still current. |
:'''Standardized''' in [[#HTML401|HTML 4.0]]; still current. |
||
{{Anchor|input|input_tag}}{{XMLElement|input|Input|...|end=no}} |
{{Anchor|input|input_tag}}{{XMLElement|input|Input|...|end=no}} |
||
: |
:{{code|lang=html|code=<input>}} elements allow a variety of standard form controls to be implemented. |
||
:'''Standardized''' in [[#HTML20|HTML 2.0]]; still current. |
:'''Standardized''' in [[#HTML20|HTML 2.0]]; still current. |
||
Line 746: | Line 747: | ||
:{{XMLAttribute|type|Field Type|button|type=ENUM|need=implied}} |
:{{XMLAttribute|type|Field Type|button|type=ENUM|need=implied}} |
||
::A general-purpose button. The element < |
::A general-purpose button. The element {{code|lang=html|code=<button>}} is preferred if possible (i.e., if the client supports it) as it provides richer possibilities. |
||
:{{XMLAttribute|type|Field Type|submit|type=ENUM|need=implied}} |
:{{XMLAttribute|type|Field Type|submit|type=ENUM|need=implied}} |
||
Line 761: | Line 762: | ||
:{{XMLAttribute|type|Field Type|search|type=ENUM|need=implied}} |
:{{XMLAttribute|type|Field Type|search|type=ENUM|need=implied}} |
||
::A variation of |
::A variation of <code>text</code> which produces a search bar. |
||
:{{XMLAttribute|type|Field Type|password|type=ENUM|need=implied}} |
:{{XMLAttribute|type|Field Type|password|type=ENUM|need=implied}} |
||
::A variation of |
::A variation of <code>text</code>. The difference is that text typed in this field is {{em|masked}} – characters are displayed as an asterisk, a dot, or another replacement. The password is still submitted to the server as [[plaintext]], so an underlying secure [[communication protocol]] like [[HTTPS]] is needed if confidentiality is a concern. |
||
:{{XMLAttribute|type|Field Type|file|type=ENUM|need=implied}} |
:{{XMLAttribute|type|Field Type|file|type=ENUM|need=implied}} |
||
Line 770: | Line 771: | ||
:{{XMLAttribute|type|Field Type|tel|type=ENUM|need=implied}} |
:{{XMLAttribute|type|Field Type|tel|type=ENUM|need=implied}} |
||
::A variation of |
::A variation of <code>text</code> for [[telephone numbers]]. |
||
:{{XMLAttribute|type|Field Type|email|type=ENUM|need=implied}} |
:{{XMLAttribute|type|Field Type|email|type=ENUM|need=implied}} |
||
::A variation of |
::A variation of <code>text</code> for [[email addresses]]. |
||
:{{XMLAttribute|type|Field Type|url|type=ENUM|need=implied}} |
:{{XMLAttribute|type|Field Type|url|type=ENUM|need=implied}} |
||
::A variation of |
::A variation of <code>text</code> for [[URLs]]. |
||
:{{XMLAttribute|type|Field Type|date|type=ENUM|need=implied}} |
:{{XMLAttribute|type|Field Type|date|type=ENUM|need=implied}} |
||
Line 785: | Line 786: | ||
:{{XMLAttribute|type|Field Type|number|type=ENUM|need=implied}} |
:{{XMLAttribute|type|Field Type|number|type=ENUM|need=implied}} |
||
::A variation of |
::A variation of <code>text</code> for numbers. |
||
:{{XMLAttribute|type|Field Type|range|type=ENUM|need=implied}} |
:{{XMLAttribute|type|Field Type|range|type=ENUM|need=implied}} |
||
Line 794: | Line 795: | ||
:{{XMLAttribute|type|Field Type|hidden|type=ENUM|need=implied}} |
:{{XMLAttribute|type|Field Type|hidden|type=ENUM|need=implied}} |
||
:: |
::<code>hidden</code> inputs are not visible in the rendered page, but allow a designer to maintain a copy of data that needs to be submitted to the server as part of the form. This may, for example, be data that this web user entered or selected on a previous form that needs to be processed in conjunction with the current form. Not displayed to the user but data can still be altered client-side by editing the HTML source. |
||
{{Anchor|isindex|isindex_tag}}{{XMLElement|isindex|Index|...|end=no|deprecated=1}} |
{{Anchor|isindex|isindex_tag}}{{XMLElement|isindex|Index|...|end=no|deprecated=1}} |
||
: |
:{{code|lang=html|code=<isindex>}} could either appear in the document head or in the body, but only once in a document. |
||
: |
:{{code|lang=html|code=<isindex>}} operated as a primitive HTML search form; but was {{lang|la|[[de facto]]}} obsoleted by more advanced HTML forms introduced in the early to mid-1990s. Represents a set of hyperlinks composed of a base URI, an [[ampersand]] and [[Percent-encoding|percent-encoded]] keywords separated by [[plus sign]]s. |
||
: |
:<code>ISINDEX</code> existed in ''[[#HTMLTAGS|HTML Tags]]''; '''standardized''' in [[#HTML20|HTML 2.0]]; '''deprecated''' in [[#HTML401|HTML 4.0 Transitional]]; '''invalid''' in [[#HTML401|HTML 4.0 Strict]]. |
||
{{anchor|keygen|keygen_tag}}{{XMLElement|keygen|Key pair generator|...}} |
{{anchor|keygen|keygen_tag}}{{XMLElement|keygen|Key pair generator|...}} |
||
Line 806: | Line 807: | ||
{{Anchor|label|label_tag}}{{XMLElement|label|Label|...|atr={{XMLAttribute|for|For|id|type=ENUM|need=implied}}}} |
{{Anchor|label|label_tag}}{{XMLElement|label|Label|...|atr={{XMLAttribute|for|For|id|type=ENUM|need=implied}}}} |
||
:Creates a label for a form input |
:Creates a label for a form input, such as <code>radio</code>. Clicking on the label fires a click on the matching input. |
||
:'''Standardized''' in [[#HTML401|HTML 4.0]]; still current. |
:'''Standardized''' in [[#HTML401|HTML 4.0]]; still current. |
||
{{Anchor|legend|legend_tag}}{{XMLElement|legend|Legend|...}} |
{{Anchor|legend|legend_tag}}{{XMLElement|legend|Legend|...}} |
||
:A legend (caption) for a |
:A legend (caption) for a {{code|lang=html|code=<fieldset>}}. |
||
:'''Standardized''' in [[#HTML401|HTML 4.0]]; still current. |
:'''Standardized''' in [[#HTML401|HTML 4.0]]; still current. |
||
{{anchor|meter|meter_tag}}{{XMLElement|meter|Meter|...}} |
{{anchor|meter|meter_tag}}{{XMLElement|meter|Meter|...}} |
||
:A meter which needs a |
:A meter which needs a <code>value</code> attribute. Can also have: <code>min</code>, <code>low</code>, <code>high</code>, and <code>max</code>. |
||
:'''Standardized''' in [[#HTML5|HTML5]]. |
:'''Standardized''' in [[#HTML5|HTML5]]. |
||
{{Anchor|option|option_tag}}{{XMLElement|option|Select List Option|...|atr={{XMLAttribute|value|Value|x|type=ANY|need=required}}}} |
{{Anchor|option|option_tag}}{{XMLElement|option|Select List Option|...|atr={{XMLAttribute|value|Value|x|type=ANY|need=required}}}} |
||
:Creates an item in a < |
:Creates an item in a {{code|lang=html|code=<select>}} list. |
||
:'''Standardized''' in [[#HTML20|HTML 2.0]]; still current. |
:'''Standardized''' in [[#HTML20|HTML 2.0]]; still current. |
||
{{Anchor|optgroup|optgroup_tag}}{{XMLElement|optgroup|Options Group|...|}} |
{{Anchor|optgroup|optgroup_tag}}{{XMLElement|optgroup|Options Group|...|}} |
||
:Identifies a group of |
:Identifies a group of {{code|lang=html|code=<option>}} elements in a {{code|lang=html|code=<select>}} list. |
||
:'''Standardized''' in [[#HTML401|HTML 4.0]]; still current. |
:'''Standardized''' in [[#HTML401|HTML 4.0]]; still current. |
||
Line 838: | Line 839: | ||
{{Anchor|textarea|textarea_tag}}{{XMLElement|textarea|Multiline Textarea|...|atr={{XMLAttribute|rows|Rows|8|type=INT}}}} |
{{Anchor|textarea|textarea_tag}}{{XMLElement|textarea|Multiline Textarea|...|atr={{XMLAttribute|rows|Rows|8|type=INT}}}} |
||
:A multiple-line text area, the size of which is specified by <code>cols</code> (where |
:A multiple-line text area, the size of which is specified by <code>cols</code> (where a column is a one-character width of text) and <code>rows</code> [[HTML attributes]]. The content of this element is restricted to plain text, which appears in the text area as default text when the page is loaded. |
||
:'''Standardized''' in [[#HTML20|HTML 2.0]]; still current. |
:'''Standardized''' in [[#HTML20|HTML 2.0]]; still current. |
||
Line 845: | Line 846: | ||
;{{Anchor|table|table_tag}}{{XMLElement|table|Table|...|}} |
;{{Anchor|table|table_tag}}{{XMLElement|table|Table|...|}} |
||
:Identifies a table. Several [[HTML attributes]] are possible in HTML Transitional, but most of these are invalid in HTML Strict and can be replaced with style sheets. The |
:Identifies a table. Several [[HTML attributes]] are possible in HTML Transitional, but most of these are invalid in HTML Strict and can be replaced with style sheets. The <code>summary</code> attribute is informally required for accessibility purposes, though its usage is not simple. |
||
:Proposed in the [[#HTML30|HTML 3.0 Drafts]]; '''Standardized''' in [[#HTML32|HTML 3.2]]; still current. |
:Proposed in the [[#HTML30|HTML 3.0 Drafts]]; '''Standardized''' in [[#HTML32|HTML 3.2]]; still current. |
||
;{{Anchor|tr|tr_tag}}{{XMLElement|tr|Table Row|...|}} |
;{{Anchor|tr|tr_tag}}{{XMLElement|tr|Table Row|...|}} |
||
:Contains a row of cells in a table. |
:Contains a row of cells in a {{code|lang=html|code=<table>}}. |
||
:Proposed in the [[#HTML30|HTML 3.0 Drafts]]; '''Standardized''' in [[#HTML32|HTML 3.2]]; still current. |
:Proposed in the [[#HTML30|HTML 3.0 Drafts]]; '''Standardized''' in [[#HTML32|HTML 3.2]]; still current. |
||
;{{Anchor|th|th_tag}}{{XMLElement|th|Table Header Cell|...|}} |
;{{Anchor|th|th_tag}}{{XMLElement|th|Table Header Cell|...|}} |
||
:A table header cell; contents are conventionally displayed bold and centered. An aural user agent may use a louder voice for these items. |
:A {{code|lang=html|code=<table>}} header cell; contents are conventionally displayed bold and centered. An [[aural]] user agent may use a louder voice for these items. |
||
:Proposed in the [[#HTML30|HTML 3.0 Drafts]]; '''Standardized''' in [[#HTML32|HTML 3.2]]; still current. |
:Proposed in the [[#HTML30|HTML 3.0 Drafts]]; '''Standardized''' in [[#HTML32|HTML 3.2]]; still current. |
||
;{{Anchor|td|td_tag}}{{XMLElement|td|Table Data Cell|...|}} |
;{{Anchor|td|td_tag}}{{XMLElement|td|Table Data Cell|...|}} |
||
:A table data cell. |
:A {{code|lang=html|code=<table>}} data cell. |
||
:Proposed in the [[#HTML30|HTML 3.0 Drafts]]; '''Standardized''' in [[#HTML32|HTML 3.2]]; still current. |
:Proposed in the [[#HTML30|HTML 3.0 Drafts]]; '''Standardized''' in [[#HTML32|HTML 3.2]]; still current. |
||
;{{Anchor|colgroup|colgroup_tag}}{{XMLElement|colgroup|Column Group|...|}} |
;{{Anchor|colgroup|colgroup_tag}}{{XMLElement|colgroup|Column Group|...|}} |
||
:Specifies a column group in a table. |
:Specifies a column group in a {{code|lang=html|code=<table>}}. |
||
:Proposed in [[#HTMLTABLES|HTML Tables]]; '''Standardized''' in [[#HTML401|HTML 4.0]]; still current. |
:Proposed in [[#HTMLTABLES|HTML Tables]]; '''Standardized''' in [[#HTML401|HTML 4.0]]; still current. |
||
;{{Anchor|col|col_tag}}{{XMLElement|col|Table Column|...|}} |
;{{Anchor|col|col_tag}}{{XMLElement|col|Table Column|...|}} |
||
:Specifies a column in a table. |
:Specifies a column in a {{code|lang=html|code=<table>}}. |
||
:Proposed in [[#HTMLTABLES|HTML Tables]]; '''Standardized''' in [[#HTML401|HTML 4.0]]; still current. |
:Proposed in [[#HTMLTABLES|HTML Tables]]; '''Standardized''' in [[#HTML401|HTML 4.0]]; still current. |
||
;{{Anchor|caption|caption_tag}}{{XMLElement|caption|Table Caption|...|}} |
;{{Anchor|caption|caption_tag}}{{XMLElement|caption|Table Caption|...|}} |
||
:Specifies a caption for a table. |
:Specifies a caption for a {{code|lang=html|code=<table>}}. |
||
:Proposed in the [[#HTML30|HTML 3.0 Drafts]]; '''Standardized''' in [[#HTML32|HTML 3.2]]; still current. |
:Proposed in the [[#HTML30|HTML 3.0 Drafts]]; '''Standardized''' in [[#HTML32|HTML 3.2]]; still current. |
||
;{{Anchor|thead|thead_tag}}{{XMLElement|thead|Table Header|...|}} |
;{{Anchor|thead|thead_tag}}{{XMLElement|thead|Table Header|...|}} |
||
:Specifies the header part of a table. This section may be repeated by the user agent if the table is split across pages (in printing or other paged media). |
:Specifies the header part of a {{code|lang=html|code=<table>}}. This section may be repeated by the user agent if the table is split across pages (in printing or other paged media). |
||
:Proposed in [[#HTMLTABLES|HTML Tables]]; '''Standardized''' in [[#HTML401|HTML 4.0]]; still current. |
:Proposed in [[#HTMLTABLES|HTML Tables]]; '''Standardized''' in [[#HTML401|HTML 4.0]]; still current. |
||
;{{Anchor|tbody|tbody_tag}}{{XMLElement|tbody|Table Body|...|}} |
;{{Anchor|tbody|tbody_tag}}{{XMLElement|tbody|Table Body|...|}} |
||
:Specifies a body of data for |
:Specifies a body of data for a {{code|lang=html|code=<table>}}. |
||
:Proposed in [[#HTMLTABLES|HTML Tables]]; '''Standardized''' in [[#HTML401|HTML 4.0]]; still current. |
:Proposed in [[#HTMLTABLES|HTML Tables]]; '''Standardized''' in [[#HTML401|HTML 4.0]]; still current. |
||
;{{Anchor|tfoot|tfoot_tag}}{{XMLElement|tfoot|Table Footer|...|}} |
;{{Anchor|tfoot|tfoot_tag}}{{XMLElement|tfoot|Table Footer|...|}} |
||
:Specifies the footer part of a table. Like |
:Specifies the footer part of a {{code|lang=html|code=<table>}}. Like {{code|lang=html|code=<thead>}}, this section may be repeated by the user agent if the table is split across pages (in printing or other paged media). |
||
:Proposed in [[#HTMLTABLES|HTML Tables]]; '''Standardized''' in [[#HTML401|HTML 4.0]]; still current. |
:Proposed in [[#HTMLTABLES|HTML Tables]]; '''Standardized''' in [[#HTML401|HTML 4.0]]; still current. |
||
Line 878: | Line 879: | ||
{{Main|Framing (World Wide Web)}} |
{{Main|Framing (World Wide Web)}} |
||
Frames allow a visual HTML Browser window to be split into segments, each of which can show a different document. This can lower bandwidth use, as repeating parts of a layout can be used in one frame, while variable content is displayed in another. This may come at a certain usability cost, especially in non-visual user agents,<ref>{{cite web|url=http://www.washington.edu/doit/are-frames-accessible|title=Are frames accessible?|quote=...frames do present additional usability challenges that are unique to users with disabilities, particularly those who use screen readers.}}</ref> due to separate and independent documents (or websites) being displayed adjacent to each other and being allowed to interact with the same parent window. Because of this cost, frames (excluding the {{ |
Frames allow a visual HTML Browser window to be split into segments, each of which can show a different document. This can lower bandwidth use, as repeating parts of a layout can be used in one frame, while variable content is displayed in another. This may come at a certain usability cost, especially in non-visual user agents,<ref>{{cite web|url=http://www.washington.edu/doit/are-frames-accessible|title=Are frames accessible?|quote=...frames do present additional usability challenges that are unique to users with disabilities, particularly those who use screen readers.}}</ref> due to separate and independent documents (or websites) being displayed adjacent to each other and being allowed to interact with the same parent window. Because of this cost, frames (excluding the {{code|lang=html|code=<iframe>}} element) are only allowed in HTML 4.01 Frame-set. Iframes can also hold documents on different servers. In this case the interaction between windows is blocked by the browser. Sites like [[Facebook]] and [[Twitter]] use iframes to display content (plugins) on third party websites. Google [[AdSense]] uses iframes to display banners on third party websites. |
||
In HTML 4.01, a document may contain a {{ |
In HTML 4.01, a document may contain a {{code|lang=html|code=<head>}} and a {{code|lang=html|code=<body>}} {{em|or}} a {{code|lang=html|code=<head>}} and a {{code|lang=html|code=<frameset>}}, but not both a {{code|lang=html|code=<body>}} and a {{code|lang=html|code=<frameset>}}. However, {{code|lang=html|code=<iframe>}} can be used in a normal document body. |
||
;{{Anchor|frameset|frameset_tag}}{{XMLElement|frameset|Frameset|...|deprecated=1}} |
;{{Anchor|frameset|frameset_tag}}{{XMLElement|frameset|Frameset|...|deprecated=1}} |
||
:Contains the set of frame elements for a document. The layout of frames is given by comma separated lists in the <code>rows</code> and <code>cols</code> [[HTML attributes]]. |
:Contains the set of {{code|lang=html|code=<frame>}} elements for a document. The layout of frames is given by comma separated lists in the <code>rows</code> and <code>cols</code> [[HTML attributes]]. |
||
:'''Standardized''' in [[#HTML401|HTML 4.0]] Frameset, '''obsolete''' in HTML5. |
:'''Standardized''' in [[#HTML401|HTML 4.0]] Frameset, '''obsolete''' in HTML5. |
||
;{{Anchor|frame|frame_tag}}{{XMLElement|frame|Frame|...|end=no|deprecated=1}} |
;{{Anchor|frame|frame_tag}}{{XMLElement|frame|Frame|...|end=no|deprecated=1}} |
||
:Defines a single frame, or region, within the < |
:Defines a single frame, or region, within the {{code|lang=html|code=<frameset>}}. A separate document is linked to a frame using the <code>src</code> attribute inside the {{code|lang=html|code=<frame>}} element. |
||
:'''Standardized''' in [[#HTML401|HTML 4.0]] Frameset, '''obsolete''' in HTML5. |
:'''Standardized''' in [[#HTML401|HTML 4.0]] Frameset, '''obsolete''' in HTML5. |
||
;{{Anchor|noframes|noframes_tag}}{{XMLElement|noframes|Frame Support Fallback|...|deprecated=1}} |
;{{Anchor|noframes|noframes_tag}}{{XMLElement|noframes|Frame Support Fallback|...|deprecated=1}} |
||
:Contains normal HTML content for user agents that don't support |
:Contains normal HTML content for user agents that don't support {{code|lang=html|code=<frame>}} elements. |
||
:'''Standardized''' in [[#HTML401|HTML 4.0]] Transitional, '''obsolete''' in HTML5. |
:'''Standardized''' in [[#HTML401|HTML 4.0]] Transitional, '''obsolete''' in HTML5. |
||
;{{Anchor|iframe|iframe_tag}}{{XMLElement|iframe|Inline Frame|...|}} |
;{{Anchor|iframe|iframe_tag}}{{XMLElement|iframe|Inline Frame|...|}} |
||
:An inline frame places another HTML document in a frame. Unlike an |
:An inline frame places another HTML document in a frame. Unlike an {{code|lang=html|code=<object>}} element, an {{code|lang=html|code=<iframe>}} can be the "target" frame for links defined by other elements, and it can be selected by the user agent as the focus for printing, viewing its source, and so on. |
||
:The content of the element is used as alternative text to be displayed if the browser does not support |
:The content of the element is used as alternative text to be displayed if the browser does not support inline frames. |
||
:First introduced by Microsoft Internet Explorer in 1997, '''standardized''' in [[#HTML401|HTML 4.0]] Transitional, '''allowed''' in HTML5. |
:First introduced by Microsoft Internet Explorer in 1997, '''standardized''' in [[#HTML401|HTML 4.0]] Transitional, '''allowed''' in HTML5. |
||
===<code>longdesc</code> attribute=== |
|||
===Longdesc=== |
|||
In [[HTML]], '''longdesc''' is an attribute used within the |
In [[HTML]], '''<code>longdesc</code>''' is an attribute used within the {{code|lang=html|code=<image>}}, {{code|lang=html|code=<frame>}}, or {{code|lang=html|code=<iframe>}} elements. It is supposed to be a [[URL]]{{refn|group=note|Strictly an [[Internationalized resource identifier|IRI]], not a URL; although URLs are a subset of IRIs.}} to a document that provides a '''long description''' for the image, frame, or iframe in question.<ref>{{cite web|url=http://www.w3.org/TR/REC-html40/struct/objects.html|title=Objects, Images, and Applets|publisher=W3C|accessdate=2008-12-20}}</ref> Note that this attribute should contain a URL, and {{em|not}} – as is commonly mistaken – the text of the description itself. |
||
<code>longdesc</code> was designed to be used by [[screen reader]]s to display image information for computer users with [[accessibility]] issues, such as the blind or visually impaired, and is widely implemented by both web browsers and screen readers.<ref>{{cite web|url=http://www.w3.org/html/wg/wiki/ChangeProposals/InstateLongdesc/Implementation|title=InState Longdesc|accessdate=2011-09-05}}</ref> Some developers object that |
|||
<ref>{{cite web|url=http://www.webaim.org/techniques/images/longdesc.php#longdesc|title=Creating Accessible Images|publisher=WebAim|accessdate=2008-12-20}}</ref> it is actually seldom used for this purpose |
<ref>{{cite web|url=http://www.webaim.org/techniques/images/longdesc.php#longdesc|title=Creating Accessible Images|publisher=WebAim|accessdate=2008-12-20}}</ref> it is actually seldom used for this purpose because there are relatively few authors who use the attribute and most of those authors use it incorrectly; thus, they recommend deprecating <code>longdesc</code>.<ref>{{citation|url=http://wiki.whatwg.org/wiki/Longdesc_usage |title=Longdesc usage - WHATWG Wiki |publisher=Wiki.whatwg.org |date= |accessdate=2012-03-26}}</ref> The publishing industry has responded, advocating the retention of <code>longdesc</code>.<ref>{{cite web|url=http://www.w3.org/Bugs/Public/show_bug.cgi?id=13461|title=Bug 13461 - Commentary on Issue #30 (longdesc) from the Association of American Publishers |accessdate=2011-09-05}}</ref> |
||
====Example==== |
====Example==== |
||
Line 915: | Line 916: | ||
====Linking to the long description in the text==== |
====Linking to the long description in the text==== |
||
Since very few graphical browsers support making the link available natively (Opera and iCab being the exceptions), it is useful to include a link to the description page near the < |
Since very few graphical browsers support making the link available natively (Opera and iCab being the exceptions), it is useful to include a link to the description page near the {{code|lang=html|code=<img>}} element whenever possible, as this can also aid sighted users. |
||
=====Example===== |
=====Example===== |
||
Line 931: | Line 932: | ||
:'''Deprecated''' in [[#HTML32|HTML 3.2]]; '''obsolete''' in [[#HTML5|HTML5]].<ref>{{cite web|url=https://developer.mozilla.org/en-US/docs/Web/HTML/Element/listing|title=<listing>|website=MDN Web Docs}}</ref> |
:'''Deprecated''' in [[#HTML32|HTML 3.2]]; '''obsolete''' in [[#HTML5|HTML5]].<ref>{{cite web|url=https://developer.mozilla.org/en-US/docs/Web/HTML/Element/listing|title=<listing>|website=MDN Web Docs}}</ref> |
||
;{{Anchor|plaintext|plaintext_tag}}{{XMLElement|plaintext|Plaintext|...|deprecated=1|end=no}} |
;{{Anchor|plaintext|plaintext_tag}}{{XMLElement|plaintext|Plaintext|...|deprecated=1|end=no}} |
||
: |
:{{code|lang=html|code=<plaintext>}} does not have an end tag as it terminates the markup and causes the rest of the document to be parsed as if it were [[plaintext]]. |
||
:< |
:{{code|lang=html|code=<plaintext>}} existed in ''[[#HTMLTAGS|HTML Tags]]''; '''deprecated''' in [[#HTML20|HTML 2.0]]; '''invalid''' in [[#HTML401|HTML 4.0]]. |
||
;{{Anchor|xmp|xmp_tag}}{{XMLElement|xmp|HTML Example|...|deprecated=1}} |
;{{Anchor|xmp|xmp_tag}}{{XMLElement|xmp|HTML Example|...|deprecated=1}} |
||
:This element displayed the text inside the tags in a monospace font and without interpreting the HTML. The [[#HTML20|HTML 2.0]] specification recommended rendering the element at 80 characters per line. |
:This element displayed the text inside the tags in a monospace font and without interpreting the HTML. The [[#HTML20|HTML 2.0]] specification recommended rendering the element at 80 characters per line. |
||
Line 938: | Line 939: | ||
;{{Anchor|nextid|nextid_tag}}{{XMLElement|nextid|NeXT ID|...|deprecated=1|end=no}} |
;{{Anchor|nextid|nextid_tag}}{{XMLElement|nextid|NeXT ID|...|deprecated=1|end=no}} |
||
:This element enabled NeXT web designing tool to generate automatic NAME labels for its anchors and was itself automatically generated.<ref>{{cite web|url=https://developer.mozilla.org/en-US/docs/Web/HTML/Element/nextid|title=<nextid>: The NeXT ID element (Obsolete)|website=MDN Web Docs}}</ref> |
:This element enabled NeXT web designing tool to generate automatic NAME labels for its anchors and was itself automatically generated.<ref>{{cite web|url=https://developer.mozilla.org/en-US/docs/Web/HTML/Element/nextid|title=<nextid>: The NeXT ID element (Obsolete)|website=MDN Web Docs}}</ref> |
||
:< |
:{{code|lang=html|code=<nextid>}} existed in ''[[#HTMLTAGS|HTML Tags]]'' (described as obsolete); '''deprecated''' in [[#HTML20|HTML 2.0]]; '''invalid''' in [[#HTML32|HTML 3.2]] and later. |
||
==Non-standard elements== |
==Non-standard elements== |
||
Line 944: | Line 945: | ||
This section lists some widely used obsolete elements, which means they are not used in [[Validator|valid]] code. They may not be supported in all user agents. |
This section lists some widely used obsolete elements, which means they are not used in [[Validator|valid]] code. They may not be supported in all user agents. |
||
;{{Anchor|blink}}{{XMLElement|blink|Blink|...|deprecated=1}} |
;{{Anchor|blink}}{{XMLElement|blink|Blink|...|deprecated=1}} |
||
:Causes text to blink. Introduced in imitation of the [[ANSI escape code]]s. Can be done with CSS where supported: |
:Causes text to blink. Introduced in imitation of the [[ANSI escape code]]s. Can be done with CSS where supported: {{code|lang=css|code={text-decoration: blink}<nowiki />}} (This effect may have negative consequences for people with [[photosensitive epilepsy]];<ref name="WCAG">{{cite web|url=http://www.w3.org/TR/WCAG10/|title=Web Content Accessibility Guidelines 1.0|first1=Wendy|last1=Chisholm|first2=Gregg|last2=Vanderheiden|first3=Ian|last3=Jacobs|publisher=World Wide Web Consortium|date=1999-05-05|accessdate=2010-07-20}}</ref> its use on the public Internet should follow the appropriate guidelines.) |
||
:< |
:{{code|lang=html|code=<blink>}} originated in [[Netscape Navigator]] and is mostly recognized by its descendants, including [[Firefox]]; '''deprecated''' or '''invalid''' in [[#HTML20|HTML 2.0]] and later. Note that the replacement CSS tag, while standard, is not required to be supported. |
||
;{{Anchor|marquee}}{{XMLElement|marquee|Marquee|...|deprecated=1}} |
;{{Anchor|marquee}}{{XMLElement|marquee|Marquee|...|deprecated=1}} |
||
:Creates scrolling text. Can be done with scripting instead. (This effect may have negative consequences for people with [[photosensitive epilepsy]];<ref name="WCAG" /> its use on the public Internet should follow the appropriate guidelines.) There are three options, including '''Alternate''', '''Scroll''' and '''slide'''. '''Scrolldelay''' can also be added. |
:Creates scrolling text. Can be done with scripting instead. (This effect may have negative consequences for people with [[photosensitive epilepsy]];<ref name="WCAG" /> its use on the public Internet should follow the appropriate guidelines.) There are three options, including '''Alternate''', '''Scroll''' and '''slide'''. '''Scrolldelay''' can also be added. |
||
:< |
:{{code|lang=html|code=<marquee>}} originated in [[Microsoft Internet Explorer]]; '''deprecated''' or '''invalid''' in [[#HTML20|HTML 4.01]] and later. |
||
;{{Anchor|nobr}}{{XMLElement|nobr|No Break|...|deprecated=1}} |
;{{Anchor|nobr}}{{XMLElement|nobr|No Break|...|deprecated=1}} |
||
:Causes text to not break at end of line, preventing word wrap where text exceeds the width of the enclosing object. Adjacent text may break before and after it. Can be done with CSS: |
:Causes text to not break at end of line, preventing word wrap where text exceeds the width of the enclosing object. Adjacent text may break before and after it. Can be done with CSS: {{code|lang=css|code={white-space: nowrap;}<nowiki />}} |
||
:< |
:{{code|lang=html|code=<nobr>}} is a proprietary element which is recognized by most browsers for compatibility reasons; '''deprecated''' or '''invalid''' in [[#HTML20|HTML 2.0]] and later. |
||
;{{Anchor|noembed}}{{XMLElement|noembed|Embed Fallback|...|deprecated=1}} |
;{{Anchor|noembed}}{{XMLElement|noembed|Embed Fallback|...|deprecated=1}} |
||
:Specifies alternative content, if the embed cannot be rendered. Replaced by the content of the < |
:Specifies alternative content, if the embed cannot be rendered. Replaced by the content of the {{code|lang=html|code=<embed>}} or {{code|lang=html|code=<object>}} element. |
||
==Comments== |
==Comments== |
||
Line 973: | Line 974: | ||
There are a few compatibility quirks involving comments: |
There are a few compatibility quirks involving comments: |
||
* Placing comments – or indeed any characters except for white-space – before the doctype will cause Internet Explorer 6 to use [[quirks mode]] for the HTML page. None of its enclosed contents are processed. |
* Placing comments – or indeed any characters except for white-space – before the doctype will cause Internet Explorer 6 to use [[quirks mode]] for the HTML page. None of its enclosed contents are processed. |
||
* For compatibility with some pre-1995 browsers, the contents of < |
* For compatibility with some pre-1995 browsers, the contents of {{code|lang=html|code=<style>}} and {{code|lang=html|code=<script>}} elements are still sometimes surrounded by comment delimiters. |
||
* The [[BlueGriffon]] HTML editor, in versions 1.7.x makes comments that are not embedded in the syntax structure {{code|lang=html|code=<style> ... {comment tags} ...</style>}} show up on screen. Other HTML editors may have this same defect. |
* The [[BlueGriffon]] HTML editor, in versions 1.7.x makes comments that are not embedded in the syntax structure {{code|lang=html|code=<style> ... {comment tags} ...</style>}} show up on screen. Other HTML editors may have this same defect. |
||
Revision as of 18:31, 1 June 2018
HTML |
---|
Comparisons |
An HTML element is an individual component of an HTML document or web page, once this has been parsed into the Document Object Model. HTML is composed of a tree of HTML nodes, such as text nodes. Each node can have HTML attributes specified. Nodes can also have content, including other nodes and text. Many HTML nodes represent semantics, or meaning. For example, the <title>
node represents the title of the document.
Concepts
Document vs. DOM
HTML documents are delivered as "documents".[note 1] These are then parsed, which turns them into the Document Object Model (DOM) internal representation, within the web browser.[note 2][note 3]
Presentation by the web browser, such as screen rendering or access by JavaScript, is then performed on this internal model, not the original document.
Early HTML documents, and to a lesser extent today, were largely invalid HTML and riddled with syntax errors. The parsing process was also required to "fix-up" these errors, as best it could. The resultant model was often not correct (i.e., it did not represent what a careless coder had originally intended), but it would at least be valid, according to the HTML standard. A valid model was produced, no matter how bad the "tag soup" supplied had been. Only in the rarest cases would the parser abandon parsing altogether.
Elements vs. tags
"Elements" and "tags" are terms that are widely confused. HTML documents contain tags, but do not contain the elements. The elements are only generated after the parsing step, from these tags.[citation needed]
As is generally understood, the position of an element is indicated as spanning from a start tag, possibly including some child content, and is terminated by an end tag.[3] This is the case for many, but not all, elements within an HTML document.
As HTML is based on SGML,[4] its parsing also depends on the use of a DTD, specifically an HTML DTD such as that for HTML 4.01.[5][note 4] The DTD specifies which element types are possible (i.e. it defines the set of element types that go to make up HTML) and it also specifies the valid combinations in which they may appear in a document. It is part of general SGML behavior that where only one valid structure is possible (per the DTD), it is not generally a requirement that the document explicitly states that structure. As a simple example, the <p>
start tag indicating the start of a paragraph element should be closed by a </p>
end tag, indicating the end of the element. Also the DTD states that paragraph elements cannot be nested. The HTML document fragment:
<p>Para 1 <p>Para 2 <p>Para 3
can thus be inferred to be equivalent to:
<p>Para 1 </p><p>Para 2 </p><p>Para 3
(If one paragraph element cannot contain another, any currently open paragraph must be closed before starting another.)
Because of this implied behavior, based on the combination of the DTD and the individual document, it is not possible to infer elements from the document tags alone, but only by also using an SGML or HTML aware parser, with knowledge of the DTD.
SGML vs. XML
SGML is complex, which has limited its widespread adoption and understanding. XML was developed as a simpler alternative. XML is similar to SGML, that can also use the DTD mechanism to specify the supported elements and their permitted combinations as document structure. XML parsing is simpler. The relation from tags to elements is always that of parsing the actual tags included in the document, without the implied closures that are part of SGML.[note 5]
In Macros HTML can be formed as XML, either through XHTML or through HTML5, the parsing of document tags as DOM elements is simplified. Once the DOM of elements is obtained, behavior beyond that point (i.e. screen rendering) is identical.[note 6]
%block;
vs. box
Part of this CSS presentation behavior is the notion of the "box model". This is applied to those elements that CSS considers to be "block" elements, set through the CSS display: block;
declaration.
HTML also has a similar concept, although different, and the two are very frequently confused. %block;
and %inline;
are groups within the HTML DTD that group elements as being either "block-level" or "inline".[7] This is used to define their nesting behavior: block-level elements cannot be placed into an inline context.[note 7] This behavior cannot be changed; it is fixed in the DTD. Block and inline elements have the appropriate and different CSS behaviors attached to them by default,[7] including the relevance of the box model for particular element types.
Note though that this CSS behavior can, and frequently is, changed from the default. Lists with <ul><li> ...
are %block;
elements and are presented as block elements by default. However, it is quite common to set these with CSS to display as an inline list.[8]
Overview
Syntax
In the HTML syntax, most elements are written with a start tag and an end tag, with the content in between. An HTML tag is composed of the name of the element, surrounded by angle brackets. An end tag also has a slash after the opening angle bracket, to distinguish it from the start tag. For example, a paragraph, which is represented by the <p>
element, would be written as:
<p>In the HTML syntax, most elements are written ...</p>
However, not all of these elements require the end tag, or even the start tag, to be present. Some elements, the so-called void elements or empty elements, do not have an end tag. A typical example is the <br />
element, which represents a significant line break, such as in a poem or an address. A void element's behavior is predefined, and it cannot contain any content or other elements. For example, an address would be written as:
<p>P. Sherman<br>42 Wallaby Way<br>Sydney</p>
When using an XHTML DTD, it is required to open and close the element with a single tag. To specify that it is a void element, a /
is included at the end of the tag (not to be confused with the /
at the beginning of a closing tag).
<p>P. Sherman<br />42 Wallaby Way<br />Sydney</p>
HTML attributes are specified inside the start tag. For example, the <abbr>
element, which represents an abbreviation, expects a <title>
attribute within its opening tag. This would be written as:
<abbr title="abbreviation">abbr.</abbr>
There are multiple kinds of HTML elements: void elements, raw text elements, and normal elements.
Void elements only have a start tag, which contains any HTML attributes. They may not contain any children, such as text or other elements. Often they are place holders for elements which reference external files, such as the image (<img />
) element. The attributes included in the element will then point to the external file in question.
Another example of a void element is the <link />
element, for which the syntax is:
<link rel="stylesheet" href="fancy.css" type="text/css">
This <link />
element points the browser at a style sheet to use when presenting the HTML document to the user. Note that in the HTML syntax, attributes don't have to be quoted if they are composed only of certain characters: letters, digits, the hyphen-minus and the full stop. When using the XML syntax (XHTML), on the other hand, all attributes must be quoted, and a trailing slash is required before the last angle bracket:
<link rel="stylesheet" href="fancy.css" type="text/css" />
Raw text elements are constructed with:
- a start tag (
<tag>
) marking the beginning of an element, which may incorporate any number of HTML attributes; - some amount of text content, but no elements (all tags, apart from the applicable end tag, will be interpreted as content);
- an end tag, in which the element name is prefixed with a slash:
</tag>
. In some versions of HTML, the end tag is optional for some elements. The end tag is required in XHTML.[example needed]
Normal elements usually have both a start tag and an end tag, although for some elements the end tag, or both tags, can be omitted. It is constructed in a similar way:
- a start tag (
<tag>
) marking the beginning of an element, which may incorporate any number of HTML attributes; - some amount of content, including text and other elements;
- an end tag, in which the element name is prefixed with a slash:
</tag>
.
HTML attributes define desired behavior or indicate additional element properties. Most attributes require a value. In HTML, the value can be left unquoted if it doesn't include spaces (name=value
), or it can be quoted with single or double quotes (name='value'
or name="value"
). In XML, those quotes are required. Boolean attributes, on the other hand, don't require a value to be specified. An example is the checked
for checkboxes:
<input type=checkbox checked>
In the XML syntax, though, the name should be repeated as the value:
<input type="checkbox" checked="checked" />
Informally, HTML elements are sometimes referred to as "tags" (an example of synecdoche), though many prefer the term tag strictly in reference to the markup delimiting the start and end of an element.
Element (and attribute) names may be written in any combination of upper or lower case in HTML, but must be in lower case in XHTML.[9] The canonical form was upper-case until HTML 4, and was used in HTML specifications, but in recent years, lower-case has become more common.
Element standards
HTML elements are defined in a series of freely available open standards issued since 1995, initially by the IETF and subsequently by the W3C.
During the browser wars of the 1990s, developers of user agents (e.g. web browsers) often developed their own elements, some of which have been adopted in later standards. Other user agents may not recognize non-standard elements, and they will be ignored, possibly causing the page to be displayed improperly.
In 1998, XML (a simplified form of SGML) introduced mechanisms to allow anyone to develop their own elements and incorporate them in XHTML documents, for use with XML-aware user agents.[10]
Subsequently, HTML 4.01 was rewritten in an XML-compatible form, XHTML 1.0 (eXtensible HTML). The elements in each are identical, and in most cases valid XHTML 1.0 documents will be valid or nearly valid HTML 4.01 documents. This article mainly focuses on real HTML, unless noted otherwise; however, it remains applicable to XHTML. See HTML for a discussion of the minor differences between the two.
Element status
Since the first version of HTML, several elements have become outmoded, and are deprecated in later standards, or do not appear at all, in which case they are invalid (and will be found invalid, and perhaps not displayed, by validating user agents).[11]
At present, the status of elements is complicated by the existence of three types of HTML 4.01 / XHTML 1.0 DTD:
- Transitional, which contain deprecated elements, but which were intended to provide a transitional period during which authors could update their practices;
- Frameset, which are versions of the Transitional DTDs which also allow authors to write frameset documents;
- Strict, which is the up-to-date (as at 1999) form of HTML.
The first Standard (HTML 2.0) contained four deprecated elements, one of which was invalid in HTML 3.2. All four are invalid in HTML 4.01 Transitional, which also deprecated a further ten elements. All of these, plus two others, are invalid in HTML 4.01 Strict. While the frame elements are still current in the sense of being present in the Transitional and Frameset DTDs, there are no plans to preserve them in future standards, as their function has been largely replaced, and they are highly problematic for user accessibility.
(Strictly speaking, the most recent XHTML standard, XHTML 1.1 (2001), does not include frames at all; it is approximately equivalent to XHTML 1.0 Strict, but also includes the Ruby markup module.)[12]
A common source of confusion is the loose use of deprecated to refer to both deprecated and invalid status, and to elements which are expected to be formally deprecated in future.
Content vs. presentation and behavior
Since HTML 4, HTML has increasingly focused on the separation of content (the visible text and images) from presentation (like color, font size, and layout).[13] This is often referred to as a separation of concerns. HTML is used to represent the structure or content of a document, its presentation remains the sole responsibility of CSS style sheets. A default style sheet is suggested as part of the CSS standard, giving a default rendering for HTML.[14]
Behavior (interactivity) is also kept separate from content, and is handled by scripts. Images are contained in separate graphics files, separate from text, though they can also be considered part of the content of a page.
Separation of concerns allows the document to be presented by different user agents according to their purposes and abilities. For example, a user agent can select an appropriate style sheet to present a document by displaying on a monitor, printing on paper, or to determine speech characteristics in an audio-only user agent. The structural and semantic functions of the markup remain identical in each case.
Historically, user agents did not always support these features. In the 1990s, as a stop-gap, presentational elements (like <b>
and <i>
) were added to HTML, at the cost of creating problems for interoperability and user accessibility. This is now regarded as outmoded and has been superseded by style sheet-based design; most presentational elements are now deprecated.[15]
External image files are incorporated with the <img>
or <object>
elements. (With XHTML, the SVG language can also be used to write graphics within the document, though linking to external SVG files is generally simpler.)[16] Where an image is not purely decorative, HTML allows replacement content with similar semantic value to be provided for non-visual user agents.
An HTML document can also be extended through the use of scripts to provide additional behaviors beyond the abilities of HTML hyperlinks and forms.
The elements <style>
and <script>
, with related HTML attributes, provide reference points in HTML markup for links to style sheets and scripts. They can also contain instructions directly.
- In the document head,
<script>
and<style>
may either link to shared external documents, or contain embedded instructions. (The<link>
element can also be used to link style sheets.) - The style attribute is valid in most document body elements for inclusion of inline style instructions.
- Event-handling attributes, which provide links to scripts, are optional in most elements.
<script>
can occur at any point in the document body.- For user agents which do not operate scripts, the
<noscript>
element provides alternative content where appropriate; however, it can only be used as a block-level element.
Document structure elements
<html>...</html>
- The root element of an HTML document; all other elements are contained in this.
- The HTML element delimits the beginning and the end of an HTML document.
- Standardized in HTML 2.0; still current.
<head>...</head>
- Container for processing information and metadata for an HTML document.
- Standardized in HTML 2.0; still current.
- (See document head elements for child elements.)
<body>...</body>
- Container for the displayable content of an HTML document.
- Standardized in HTML 2.0; still current.
- (See document body elements for child elements.)
Document head elements
<base />
- Specifies a base URL for all relative
href
and other links in the document. Must appear before any element that refers to an external resource. HTML permits only one<base>
element for each document. The<base>
element has HTML attributes, but no contents. - A development version of
BASE
is mentioned in HTML Tags; standardized in HTML 2.0; still current.
<basefont /> (deprecated)
- Specifies a base font size, typeface, and color for the document. Used together with
<font>
elements. Deprecated in favor of style sheets. - Standardized in HTML 3.2; deprecated in HTML 4.0 Transitional; invalid in HTML 4.0 Strict.
<isindex /> (deprecated)
<isindex>
could either appear in the document head or in the body, but only once in a document. See Forms.
<link />
- Specifies links to other documents, such as previous and next links, or alternate versions.[17] A common use is to link to external style sheets, using the form:
<link rel="stylesheet" type="text/css" href="url" title="description_of_style">
[18]
- A less-common, but important, usage is to supply navigation hints consistently through use of microformats. Several common relationships are defined, that may be exposed to users through the browser interface rather than directly in the web page.
<link rel="next" href="url">
- A document's
<head>
element may contain any number of<link>
elements. The<link>
element has HTML attributes, but no contents. LINK
existed in HTML Internet Draft 1.2, and was standardized in HTML 2.0; still current.
- Can be used to specify additional metadata about a document, such as its author, publication date, expiration date, page description, keywords, or other information not provided through the other header elements and HTML attributes. Because of their generic nature,
<meta>
elements specify associative key-value pairs. In general, a meta element conveys hidden information about the document. Several meta tags can be used, all of which should be nested in the head element. The specific purpose of each<meta>
element is defined by its attributes. - In one form,
<meta>
elements can specify HTTP headers which should be sent by a web server before the actual content. For example,<meta http-equiv="foo" content="bar">
specifies that the page should be served with an HTTP header calledfoo
that has a valuebar
. - In the general form, a
<meta>
element specifiesname
and associatedcontent
HTML attributes describing aspects of the HTML page. To prevent possible ambiguity, an optional third attribute,scheme
, may be supplied to specify a semantic framework that defines the meaning of the key and its value. For example, in<meta name="foo" content="bar" scheme="DC">
the<meta>
element identifies itself as containing thefoo
element, with a value ofbar
, from the DC or Dublin Core resource description framework. - Standardized in HTML 2.0; still current.
<object>...</object>
- Used for including generic objects within the document header. Though rarely used within a
<head>
element, it could potentially be used to extract foreign data and associate it with the current document. - Standardized in HTML 4.0; still current.
<script>...</script>
- Can act as a container for script instructions or link to an external script with the optional
src
attribute.[19] Also usable in the document body to dynamically generate either both block or inline content. - Standardized in HTML 3.2; still current.
<style>...</style>
- Specifies a style for the document, usually in the form:
<style type="text/css"> ... </style>
- Can either act as a container for style instructions or link to external style sheets – for example, in CSS, with
@import
directives of the form:<style> @import url; </style>
[20]
- Standardized in HTML 3.2; still current.
<title>...</title>
- Define a document title. Required in every HTML and XHTML document. User agents may use the title in different ways. For example:
- Web browsers usually display it in a window's title bar when the window is open, and (where applicable) in the task bar when the window is minimized.
- It may become the default file-name when saving the page.
- Web search engines' web crawlers may pay particular attention to the words used in the title.
- The
<title>
element must not contain other elements, only text. Only one<title>
element is permitted in a document. <title>
existed in HTML Tags, and was standardized in HTML 2.0; still current.
Document body elements
In visual browsers, displayable elements can be rendered as either block or inline. While all elements are part of the document sequence, block elements appear within their parent elements:
- as rectangular objects which do not break across lines;
- with block margins, width and height properties which can be set independently of the surrounding elements.
Conversely, inline elements are treated as part of the flow of document text; they cannot have margins, width or height set, and do break across lines.
Block elements
Block elements, or block-level elements, have a rectangular structure. By default, these elements will span the entire width of its parent element, and will thus not allow any other element to occupy the same horizontal space as it is placed on.
The rectangular structure of a block element is often referred to as the box model, and is made up of several parts. Each element contains the following:
- The content of an element is the actual text (or other media) placed between the opening and closing tags of an element.
- The padding of an element is the space around that content, which still form part of said element. Padding is physically part of an element, and should not be used to create white space between two elements. Any background style assigned to the element, such as a background image or color, will be visible within the padding. Increasing the size of an element's padding increases the amount of space this element will take up.
- The border of an element is the absolute end of an element, and spans the perimeter of that element. The thickness of a border increases the size of an element.
- The margin of an element is the white-space that surrounds an element. The content, padding and border of any other element will not be allowed to enter this area, unless forced to do so by some advanced CSS placement. Using most standard DTDs, margins on the left and right of different elements will push each other away. Margins on the top or bottom of an element, on the other hand, will not stack, or will intermingle. This means that the white-space between these elements will be as big as the larger margin between them.
The above section refers only to the detailed implementation of CSS rendering and has no relevance to HTML elements themselves.
Basic text
<p>...</p>
- Creates a paragraph, perhaps the most common block level element.
P
existed in HTML Tags, and was standardized in HTML 2.0; still current.
<h1>...</h1>
<h2>...</h2>
<h3>...</h3>
<h4>...</h4>
<h5>...</h5>
<h6>...</h6>
- Section headings at different levels.
h1
delimits the highest-level heading,h2
the next level down (sub-section),h3
for a level below that, and so on toh6
. They are sometimes referred to collectively ashn
tags, n meaning any of the available heading levels. - Most visual browsers show headings as large bold text by default, though this can be overridden with CSS. Heading elements are not intended merely for creating large or bold text – in fact, they should not be used for explicitly styling text. Rather, they describe the document’s structure and organization. Some programs use them to generate outlines and tables of contents.
- Headings existed in HTML Tags, and were standardized in HTML 2.0; still current.
Lists
<dl>...</dl>
- A description list (a.k.a. association list), which consists of name–value groups,[21] and was known as a definition list prior to HTML5.[22] Description lists are intended for groups of "terms and definitions, metadata topics and values, questions and answers, or any other groups of name–value data".[23]
DL
existed in HTML Tags, and was standardized in HTML 2.0; still current.
<dt>...</dt>
- A name in a description list (previously definition term in a definition list).
DT
existed in HTML Tags, and was standardized in HTML 2.0; still current.
<dd>...</dd>
- A value in a description list (previously definition data in a definition list).
DD
existed in HTML Tags, and was standardized in HTML 2.0; still current.
<ol>...</ol>
- An ordered (enumerated) list. The
type
attribute can be used to specify the kind of marker to use in the list, but style sheets give more control. The default is Arabic numbering. CSS:list-style-type: foo
. HTML attribute:<ol type="foo">
, in either case, replacingfoo
with one of the following:A
for A, B, C...a
for a, b, c...I
for I, II, III...i
for i, ii, iii...1
for 1, 2, 3...
OL
existed in HTML Internet Draft 1.2, and was standardized in HTML 2.0; still current.
<ul>...</ul>
- An unordered (bulleted) list. Style sheets can be used to specify the list marker:
list-style-type: foo
. The default marker type isdisc
, other values aresquare
,circle
andnone
. UL
existed in HTML Tags, and was standardized in HTML 2.0; still current.
<li>...</li>
- A list item in ordered (
ol
) or unordered (ul
) lists. LI
existed in HTML Tags, and was standardized in HTML 2.0; still current.
<dir>...</dir> (deprecated)
- A directory listing. The original purpose of this element was never widely supported; deprecated in favor of
<ul>
. DIR
existed in HTML Tags, and was standardized in HTML 2.0; deprecated in HTML 4.0 Transitional; invalid in HTML 4.0 Strict.
Other block elements
<address>...</address>
- Contact information for the document author.
ADDRESS
existed in HTML Tags, and was standardized in HTML 2.0; still current.
<article>...</article>
- Used for articles and other similar content.
- Standardized in HTML5.
<aside>...</aside>
- Used for content in a document which is separate from the main page content, for example, sidebars or advertising.
- Standardized in HTML5.
<blockquote>...</blockquote>
- A block level quotation, for when the quotation includes block level elements, e.g. paragraphs. The
cite
attribute may give the source, and must be a fully qualified Uniform Resource Identifier. - The default presentation of block quotations in visual browsers is usually to indent them from both margins. This has led to the element being unnecessarily used just to indent paragraphs, regardless of semantics. For quotations not containing block level elements see the quote (
<q>
) element. BLOCKQUOTE
existed in HTML Internet Draft 1.2, and was standardized in HTML 2.0; still current. See blockquote element for more information.
<center>...</center> (deprecated)
- Creates a block-level center-aligned division. Deprecated in favor of
<div>
or another element with centering defined using style sheets. - Standardized in HTML 3.2; deprecated in HTML 4.0; not supported in HTML5.
<del>...</del>
- Marks a deleted section of content. This element can also be used as inline.
- Standardized in HTML 4.0; still current.
<div>...</div>
- A block-level logical division. A generic element with no semantic meaning used to distinguish a document section, usually for purposes such as presentation or behavior controlled by style sheets or DOM calls.
- Proposed in the HTML 3.0 Drafts; Standardized in HTML 3.2; still current.
<figure>...</figure>
- Used to group images and captions, along with
figcaption
. - Standardized in HTML5.
<figcaption>...</figcaption>
- A caption for an image. Always placed inside the figure element.
- Standardized in HTML5.
<footer>...</footer>
- Used for document footers. These may contain author or copyright information, or links to other pages.
- Standardized in HTML5.
<header>...</header>
- Used for document headers. These typically contain content introducing the page.
- Standardized in HTML5.
<hr />
- A horizontal rule. Presentational rules can also be drawn with style sheets.
- Standardized in HTML 2.0; still current.
<ins>...</ins>
- Marks a section of inserted content. This element can also be used as inline.
- Standardized in HTML 4.0; still current.
<main>...</main>
- Contains the main content of a document.
- Standardized in HTML5.
<menu>...</menu>
- HTML 2.0: A menu listing. Should be more compact than a
<ul>
list. MENU
existed in HTML Tags, and was standardized in HTML 2.0; deprecated in HTML 4.0 Transitional; invalid in HTML 4.0 Strict; but then redefined in HTML5.
<nav>...</nav>
- Used in navigational sections of articles (areas of webpages which contain links to other webpages).
- Standardized in HTML5.
<noscript>...</noscript>
- Replacement content for scripts. Unlike script this can only be used as a block-level element.
- Standardized in HTML 4.0; still current.
<pre>...</pre>
- Pre-formatted text. Text within this element is typically displayed in a non-proportional font exactly as it is laid out in the file (see ASCII art). Whereas browsers ignore white-space for other HTML elements, in
pre
, white-space should be rendered as authored. (With the CSS properties:{white-space: pre; font-family: monospace;}
, other elements can be presented in the same way.) This element can contain any inline element except: image (IMG
), object (OBJECT
), big font size (BIG
), small font size (SMALL
), superscript (SUP
), and subscript (SUB
). PRE
existed in HTML Internet Draft 1.2, and was standardized in HTML 2.0; still current.
<section>...</section>
- Used for generic sections of a document. This is different from
<div>
in that it is only used to contain sections of a page, which the W3C defines as a group of content with a similar theme. - Standardized in HTML5.
<script>...</script>
- Places a script in the document. Also usable in the head and in inline contexts.
- Note:
SCRIPT
is not itself either a block or inline element; by itself it should not display at all, but it can contain instructions to dynamically generate either both block or inline content.
- Note:
- Standardized in HTML 3.2; still current.
Inline elements
Inline elements cannot be placed directly inside the <body>
element; they must be wholly nested within block-level elements.[24]
Anchor
<a>...</a>
- An anchor element is called an anchor because web designers can use it to "anchor" a URL to some text on a web page. When users view the web page in a browser, they can click the text to activate the link and visit the page whose URL is in the link.[25]
- In HTML, an anchor can be either the origin (the anchor text) or the target (destination) end of a hyperlink.
- With the attribute
href
,[26] the anchor becomes a hyperlink to either another part of the document or another resource (e.g. a webpage) using an external URL. Alternatively (and sometimes concurrently), with thename
orid
HTML attributes set, the element becomes a target. A Uniform Resource Locator can link to this target via a fragment identifier. In HTML5, any element can now be made into a target by using theid
attribute,[27] so using<a name="foo">...</a>
is not necessary, although this way of adding anchors continues to work. - To illustrate: the header of a table of contents section on
example.com
could be turned into a target by writing=Table of contents=
- Continuing with this example, now that the section has been marked up as a target, it can be referred to from external sites with a link like
<a href="http://example.com#contents">see contents</a>
- or with a link on the same page like:
<a href="#contents">contents, above</a>
- The attribute
<title>
may be set to give brief information about the link:<a href="URL" title="additional information">link text</a>
- In most graphical browsers, when the cursor hovers over a link, the cursor changes into a hand with an extended index finger and the
<title>
is displayed in a tooltip or in some other manner. Some browsers render alt text the same way, although this is not what the specification calls for. A
existed in HTML Tags, and was standardized in HTML 2.0; still current.
Phrase elements
General
<abbr>...</abbr>
- Marks an abbreviation, and can make the full form available:
<abbr title="abbreviation">abbr.</abbr>
- Standardized in HTML 4.0; still current.
<acronym>...</acronym> (deprecated)
- Similar to the
<abbr>
element, but marks an acronym:<acronym title="Hyper-Text Mark-up Language">HTML</acronym>
- Standardized in HTML 4.0; still current, not supported in HTML5.
<dfn>...</dfn>
- inline definition of a single term.
DFN
existed in HTML Internet Draft 1.2, and was fully standardized in HTML 3.2; still current.
<em>...</em>
- Emphasis (conventionally displayed in italics)
EM
existed in HTML Internet Draft 1.2, and was standardized in HTML 2.0; still current.
<strong>...</strong>
- strong emphasis (conventionally displayed bold).
- An aural user agent may use different voices for emphasis.
STRONG
existed in HTML Internet Draft 1.2, and was standardized in HTML 2.0; still current.
Computer phrase elements
These elements are useful primarily for documenting computer code development and user interaction through differentiation of source code (<code>
), source code variables (<var>
), user input (<kbd>
), and terminal output (<samp>
).
<code>...</code>
- A code snippet (
code example
). Conventionally rendered in a mono-space font. CODE
existed in HTML Internet Draft 1.2, and was standardized in HTML 2.0; still current.
<kbd>...</kbd>
- Keyboard – text to be entered by the user (kbd example).
KBD
existed in HTML Internet Draft 1.2, and was standardized in HTML 2.0; still current.
<samp>...</samp>
- Sample output – from a program or script: (samp example).
SAMP
existed in HTML Internet Draft 1.2, and was standardized in HTML 2.0; still current.
<var>...</var>
- Variable (var example).
VAR
existed in HTML Internet Draft 1.2, and was standardized in HTML 2.0; still current.
Presentation
As visual presentational markup only applies directly to visual browsers, its use is discouraged. Style sheets should be used instead. Several of these elements are deprecated or invalid in HTML 4 / XHTML 1.0, and the remainder are invalid in the current draft of XHTML 2.0. The current draft of HTML5, however, re-includes <s>
, <u>
, and <small>
, assigning new semantic meaning to each. In an HTML5 document, the use of these elements is no longer discouraged, provided that it is semantically correct.
<b>...</b>
- In HTML 4, set font to boldface where possible. Equivalent CSS:
{font-weight: bold}
.'''...'''
usually has the same effect in visual browsers, as well as having more semantic meaning, under HTML 4.01. - In HTML5, however,
<b>
has its own meaning, distinct from that of<strong>
. It denotes "text to which attention is being drawn for utilitarian purposes without conveying any extra importance and with no implication of an alternate voice or mood."[28] B
existed in HTML Internet Draft 1.2, and was standardized in HTML 2.0; still current.
<i>...</i>
- In HTML 4, set font to italic where possible. Equivalent CSS:
{font-style: italic}
.<em>...</em>
usually has the same effect in visual browsers, as well as having more semantic meaning, under HTML 4.01. - In HTML5, however,
<i>
has its own semantic meaning, distinct from that of<em>
. It denotes "a different quality of text" or "an alternative voice or mood"—e.g., a thought, a ship name, a binary species name, a foreign-language phrase, etc.[29] I
existed in HTML Internet Draft 1.2, and was standardized in HTML 2.0; still current.
<u>...</u>
- In HTML 4, underlined text. Equivalent CSS:
{text-decoration: underline}
. Deprecated in HTML 4.01. Restored in HTML5. - In HTML5, the
<u>
element denotes "a span of text with an unarticulated, though explicitly rendered, non-textual annotation, such as labelling the text as being a proper name in Chinese text (a Chinese proper name mark), or labelling the text as being misspelt." The HTML5 specification reminds developers that other elements are almost always more appropriate than<u>
and admonishes designers not to use underlined text where it could be confused for a hyper-link.[30] U
existed in HTML Internet Draft 1.2, was standardized in HTML 3.2 but was deprecated in HTML 4.0 Transitional and was invalid in HTML 4.0 Strict. Reintroduced in HTML5.
<small>...</small>
- In HTML 4, decreased font size (smaller text). Equivalent CSS:
{font-size: smaller}
- In HTML5, the
<small>
element denotes "side comments such as small print."[31] - Standardized in HTML 3.2; still current.
<s>...</s>
- In HTML 4, indicated strike-through text (
Strikethrough) and was equivalent to<strike>
. - In HTML5, the
<s>
element denotes information that is "no longer accurate or no longer relevant", and is not to be confused with<del>
, which indicates removal/deletion.[32] S
was deprecated in HTML 4.0 Transitional (having not appeared in any previous standard), and was invalid in HTML 4.0 Strict. Reintroduced in HTML5.
<big>...</big> (deprecated)
- Increased font size (bigger text). Equivalent CSS:
{font-size: larger}
- Standardized in HTML 3.2; not supported in HTML5.
<strike>...</strike>
- Strike-through text (
Strikethrough), (Equivalent CSS:{text-decoration: line-through}
) STRIKE
was standardized in HTML 3.2; deprecated in HTML 4.0 Transitional; invalid in HTML 4.0 Strict.
<tt>...</tt> (deprecated)
- Fixed-width font (typewriter-like), also known as teletype. (Equivalent CSS:
{font-family: monospace;}
) TT
existed in HTML Internet Draft 1.2, and was Standardized in HTML 2.0; not supported[33] in HTML5. Possible replacements:<kbd>
for marking keyboard input,<var>
for variables,<code>
for computer code,<samp>
for computer output.[33]
<font>...</font>
<font [color=<var>color</var>] [size=<var>size</var>] [face=<var>face</var>]>...</font>
- Can specify the font color with the
color
attribute (note the American spelling), typeface with theface
attribute, and absolute or relative size with thesize
attribute. - Examples (all uses are deprecated, use CSS equivalents if possible):
<font color="green">text</font>
creates green text.<font color="#114499">text</font>
creates text with hexadecimal color #114499.<font size="4">text</font>
creates text with size 4. Sizes are from 1 to 7. The standard size is 3, unless otherwise specified in the <body> or other tags.<font size="+1">text</font>
creates text with size 1 bigger than the standard.<font size="-1">text</font>
is opposite.<font face="Courier">text</font>
makes text with Courier font.
- Equivalent CSS for font attributes:
<font size="N">
corresponds to{font-size: Yunits}
(the HTML specification does not define the relationship between size N and unit-size Y, nor does it define a unit).<font color="red">
corresponds to{color: red}
<font face="Courier">
corresponds to{font-family: "Courier"}
- Standardized in HTML 3.2; deprecated in HTML 4.0 Transitional; invalid in HTML 4.0 Strict. Not part of HTML5.
Span
<span>...</span>
- An inline logical division. A generic element with no semantic meaning used to distinguish a document section, usually for purposes such as presentation or behavior controlled by style sheets or DOM calls.
- Standardized in HTML 4.0; still current.
Other inline elements
<br />
- A forced line break.
- Standardized in HTML 2.0; still current.
<bdi>...</bdi>
- Isolates an inline section of text that may be formatted in a different direction from other text outside of it, such as user-generated content with unknown directionality.
- Standardized in HTML5.
<bdo>...</bdo>
- Marks an inline section of text in which the reading direction is the opposite from that of the parent element.
- Standardized in HTML 4.0; still current.
<cite>...</cite>
- A citation or a reference for a quote or statement in the document.
- CITE existed in HTML Internet Draft 1.2, and was standardized in HTML 2.0; still current.
<data>...</data>
<del>...</del>
- Deleted text. Typically rendered as a strikethrough:
Deleted text. - Standardized in HTML 4.0; still current.
<ins>...</ins>
- Inserted text. Often used to mark up replacement text for
<del>
'd text. Typically rendered underlined: Inserted text. - Standardized in HTML 4.0; still current.
- Note, both
<ins>
and<del>
elements may also be used as block elements: containing other block and inline elements. However, these elements must still remain wholly within their parent element to maintain a well-formed HTML document. For example, deleting text from the middle of one paragraph across several other paragraphs and ending in a final paragraph would need to use three separate<del>
elements. Two<del>
elements would be required as inline element to indicate the deletion of text in the first and last paragraphs, and a third, used as a block element, to indicate the deletion in the intervening paragraphs.
- Note, both
<mark>...</mark>
- Produces text that looks like this. Intended for highlighting relevant text in a quotation.
Standardized in HTML5.
<q>...</q>
- An inline quotation (for block level quotation see
<blockquote>
). Quote elements may be nested. <q>
should automatically generate quotation marks in conjunction with style sheets. Practical concerns due to browser non-compliance may force authors to find workarounds.- The
cite
attribute gives the source, and must be a fully qualified URI. - Standardized in HTML 4.0; still current.
- Note: Lengthy inline quotations may be displayed as indented blocks (as
block-quote
) using style sheets. For example, with a suitable CSS rule associated withq.lengthy
:<q class="lengthy">
An inline quotation of significant length (e.g., 25 words) goes here.</q>
- Note: Lengthy inline quotations may be displayed as indented blocks (as
<rb>...</rb>
- Represents the base component of a ruby annotation.
- Standardized in HTML5.[35]
<rp>...</rp>
- Provides fallback parenthesis for browsers lacking ruby annotation support.
- Standardized in HTML5.[36]
<rt>...</rt>
- Indicates pronunciation for a character in a ruby annotation.
- Standardized in HTML5.[37]
<rtc>...</rtc>
- Semantic annotations for a ruby annotation.
- Standardized in HTML5.[38]
<ruby>...</ruby>
- Represents a ruby annotation for showing the pronunciation of East Asian characters.
- Standardized in HTML5.[39]
<script>...</script>
- Places a script in the document. Also usable in the head and in block contexts.
- Note:
<script>
is not itself either a block or inline element; by itself it should not display at all, but it can contain instructions to dynamically generate either both block or inline content.
- Note:
- Standardized in HTML 3.2; still current.
<sub>...</sub>
and <sup>...</sup>
- Mark subscript or superscript text. (Equivalent CSS:
{vertical-align: sub}
and{vertical-align: super}
respectively.) - Both were proposed in the HTML 3.0 Drafts; Standardized in HTML 3.2; still current.
<template>...</template>
- Code fragments to be copied by scripts.
- Standardized in HTML5.
<time>...</time>
- Represents a time on the 24-hour clock or a date on the Gregorian calendar, optionally with time and timezone information. Also allows times and dates to be represented in a machine-readable format.
- Standardized in HTML5.[40]
<wbr />
- An optional word break.
- Was widely used (and supported by all major browsers) for years despite being non-standard until finally being standardized in HTML5.
Images and objects
<applet>...</applet> (deprecated)
- Embeds a Java applet in the page. Deprecated in favor of
<object>
, as it could only be used with Java applets, and had accessibility limitations. - Standardized in HTML 3.2; deprecated in HTML 4.0 Transitional; invalid in HTML 4.0 Strict. As of 2011, still widely used as the implementations of the replacing
<object>
are not consistent between different browsers.
<area />
<audio>...</audio>
- Adds playable HTML5 audio to the page. The audio URL is determined using the
src
attribute. Supported audio formats vary from browser to browser. - Standardized in HTML5.
<canvas>...</canvas>
- Adds a canvas whose contents can be edited with JavaScript. Frequently used for online games.
- Standardized in HTML5.
<embed>...</embed>
- Inserts a non-standard object (like applet) or external content (typically non-HTML) into the document. Deprecated in HTML 4 in favor of
<object>
, but then was added back into the HTML5 specification[41][42]
<img />
- Used by visual user agents to insert an image in the document. The
src
attribute specifies the image URL. The requiredalt
attribute provides alternative text in case the image cannot be displayed.[43] (Thoughalt
is intended as alternative text, Microsoft Internet Explorer 7 and below render it as a tooltip if no<title>
is given.[44] Safari and Google Chrome, on the other hand, do not display the alt attribute at all.)[45]<img>
was proposed by Marc Andreessen and implemented in the NSCA Mosaic web browser.[46] IMG
existed in HTML Internet Draft 1.2, and was standardized in HTML 2.0; still current.
<map>...</map>
<object>...</object>
- Includes an object in the page of the type specified by the
type
attribute. This may be in any MIME-type the user agent understands, such as an embedded HTML page, a file to be handled by a plug-in such as Flash, a Java applet, a sound file, etc. - Standardized in HTML 4.0; still current.
<param />
- Originally introduced with
<applet>
, this element is now used with, and should only occur as a child of<object>
. It uses HTML attributes to set a parameter for the object, e.g. width, height, font, background color, etc., depending on the type of object. An object can have multiple<param>
elements. - Standardized in HTML 3.2; still current.
<source>...</source>
- Specifies different sources for audio or video. Makes use of the
src
attribute in a way similar to the<video>
and<audio>
elements. - Standardized in HTML5.
<track>...</track>
- Provides text tracks, like subtitles and captions, for audio and video.
- Standardized in HTML5.
<video>...</video>
- Adds a playable HTML5 video to the page. The video URL is determined using the
src
attribute. Supported video formats vary from browser to browser. - Standardized in HTML5.
Forms
These elements can be combined into a form or in some instances used separately as user-interface controls; in the document, they can be simple HTML or used in conjunction with Scripts. HTML markup specifies the elements that make up a form, and the method by which it will be submitted. However, some form of scripts (server-side, client-side, or both) must be used to process the user’s input once it is submitted.
(These elements are either block or inline elements, but are collected here as their use is more restricted than other inline or block elements.)
<form action="url">...</form>
- Creates a form. The
<form>
element specifies and operates the overall action of a form area, using the requiredaction
attribute. - Standardized in HTML 2.0; still current.
<button>...</button>
- A generic form button which can contain a range of other elements to create complex buttons.
- Standardized in HTML 4.0; still current.
<datalist>...</datalist>
- A list of
option
s for use in form elements. - Standardized in HTML5.
<fieldset>...</fieldset>
- A container for adding structure to forms. For example, a series of related controls can be grouped within a
<fieldset>
, which can then have a<legend>
added in order to identify their function. - Standardized in HTML 4.0; still current.
<input />
<input>
elements allow a variety of standard form controls to be implemented.- Standardized in HTML 2.0; still current.
- Input Types:
- type="checkbox"
- A checkbox. Can be checked or unchecked.
- type="radio"
- A radio button. If multiple radio buttons are given the same name, the user will only be able to select one of them from this group.
- type="button"
- A general-purpose button. The element
<button>
is preferred if possible (i.e., if the client supports it) as it provides richer possibilities.
- A general-purpose button. The element
- type="submit"
- A submit button.
- type="image"
- An image button. The image URL may be specified with the
src
attribute.
- An image button. The image URL may be specified with the
- type="reset"
- A reset button for resetting the form to default values.
- type="text"
- A one-line text input field. The
size
attribute specifies the default width of the input in character-widths.max-length
sets the maximum number of characters the user can enter (which may be greater than size).
- A one-line text input field. The
- type="search"
- A variation of
text
which produces a search bar.
- A variation of
- type="password"
- A variation of
text
. The difference is that text typed in this field is masked – characters are displayed as an asterisk, a dot, or another replacement. The password is still submitted to the server as plaintext, so an underlying secure communication protocol like HTTPS is needed if confidentiality is a concern.
- A variation of
- type="file"
- A file select field (for uploading files to a server).
- type="tel"
- A variation of
text
for telephone numbers.
- A variation of
- type="email"
- A variation of
text
for email addresses.
- A variation of
- type="url"
- A variation of
text
for URLs.
- A variation of
- type="date"
- A date selector.
- type="time"
- A time selector.
- type="number"
- A variation of
text
for numbers.
- A variation of
- type="range"
- Produces a slider for that returns a number, but the number is not visible to the user.
- type="color"
- A color picker.
- type="hidden"
hidden
inputs are not visible in the rendered page, but allow a designer to maintain a copy of data that needs to be submitted to the server as part of the form. This may, for example, be data that this web user entered or selected on a previous form that needs to be processed in conjunction with the current form. Not displayed to the user but data can still be altered client-side by editing the HTML source.
<isindex /> (deprecated)
<isindex>
could either appear in the document head or in the body, but only once in a document.<isindex>
operated as a primitive HTML search form; but was de facto obsoleted by more advanced HTML forms introduced in the early to mid-1990s. Represents a set of hyperlinks composed of a base URI, an ampersand and percent-encoded keywords separated by plus signs.ISINDEX
existed in HTML Tags; standardized in HTML 2.0; deprecated in HTML 4.0 Transitional; invalid in HTML 4.0 Strict.
<keygen>...</keygen>
- A key pair generator.
- Standardized in HTML5.
<label for="id">...</label>
- Creates a label for a form input, such as
radio
. Clicking on the label fires a click on the matching input. - Standardized in HTML 4.0; still current.
<legend>...</legend>
- A legend (caption) for a
<fieldset>
. - Standardized in HTML 4.0; still current.
<meter>...</meter>
- A meter which needs a
value
attribute. Can also have:min
,low
,high
, andmax
. - Standardized in HTML5.
<option value="x">...</option>
- Creates an item in a
<select>
list. - Standardized in HTML 2.0; still current.
<optgroup>...</optgroup>
- Identifies a group of
<option>
elements in a<select>
list. - Standardized in HTML 4.0; still current.
<output>...</output>
- The value of a form element.
- Standardized in HTML5.
<progress>...</progress>
- A bar for showing the progress of an action.
- Standardized in HTML5.
<select name="xyz">...</select>
- Creates a selection list, from which the user can select a single option. May be rendered as a dropdown list.
- Standardized in HTML 2.0; still current.
<textarea rows="8">...</textarea>
- A multiple-line text area, the size of which is specified by
cols
(where a column is a one-character width of text) androws
HTML attributes. The content of this element is restricted to plain text, which appears in the text area as default text when the page is loaded. - Standardized in HTML 2.0; still current.
Tables
The format of HTML Tables was proposed in the HTML 3.0 Drafts and the later RFC 1942 HTML Tables. They were inspired by the CALS Table Model. Some elements in these proposals were included in HTML 3.2; the present form of HTML Tables was standardized in HTML 4. (Many of the elements used within tables are neither block nor inline elements.)
<table>...</table>
- Identifies a table. Several HTML attributes are possible in HTML Transitional, but most of these are invalid in HTML Strict and can be replaced with style sheets. The
summary
attribute is informally required for accessibility purposes, though its usage is not simple. - Proposed in the HTML 3.0 Drafts; Standardized in HTML 3.2; still current.
<tr>...</tr>
- Contains a row of cells in a
<table>
. - Proposed in the HTML 3.0 Drafts; Standardized in HTML 3.2; still current.
<th>...</th>
- A
<table>
header cell; contents are conventionally displayed bold and centered. An aural user agent may use a louder voice for these items. - Proposed in the HTML 3.0 Drafts; Standardized in HTML 3.2; still current.
<td>...</td>
- A
<table>
data cell. - Proposed in the HTML 3.0 Drafts; Standardized in HTML 3.2; still current.
<colgroup>...</colgroup>
- Specifies a column group in a
<table>
. - Proposed in HTML Tables; Standardized in HTML 4.0; still current.
<col>...</col>
- Specifies a column in a
<table>
. - Proposed in HTML Tables; Standardized in HTML 4.0; still current.
<caption>...</caption>
- Specifies a caption for a
<table>
. - Proposed in the HTML 3.0 Drafts; Standardized in HTML 3.2; still current.
<thead>...</thead>
- Specifies the header part of a
<table>
. This section may be repeated by the user agent if the table is split across pages (in printing or other paged media). - Proposed in HTML Tables; Standardized in HTML 4.0; still current.
<tbody>...</tbody>
- Specifies a body of data for a
<table>
. - Proposed in HTML Tables; Standardized in HTML 4.0; still current.
<tfoot>...</tfoot>
- Specifies the footer part of a
<table>
. Like<thead>
, this section may be repeated by the user agent if the table is split across pages (in printing or other paged media). - Proposed in HTML Tables; Standardized in HTML 4.0; still current.
Frames
Frames allow a visual HTML Browser window to be split into segments, each of which can show a different document. This can lower bandwidth use, as repeating parts of a layout can be used in one frame, while variable content is displayed in another. This may come at a certain usability cost, especially in non-visual user agents,[47] due to separate and independent documents (or websites) being displayed adjacent to each other and being allowed to interact with the same parent window. Because of this cost, frames (excluding the <iframe>
element) are only allowed in HTML 4.01 Frame-set. Iframes can also hold documents on different servers. In this case the interaction between windows is blocked by the browser. Sites like Facebook and Twitter use iframes to display content (plugins) on third party websites. Google AdSense uses iframes to display banners on third party websites.
In HTML 4.01, a document may contain a <head>
and a <body>
or a <head>
and a <frameset>
, but not both a <body>
and a <frameset>
. However, <iframe>
can be used in a normal document body.
<frameset>...</frameset>(deprecated)
- Contains the set of
<frame>
elements for a document. The layout of frames is given by comma separated lists in therows
andcols
HTML attributes. - Standardized in HTML 4.0 Frameset, obsolete in HTML5.
<frame />(deprecated)
- Defines a single frame, or region, within the
<frameset>
. A separate document is linked to a frame using thesrc
attribute inside the<frame>
element. - Standardized in HTML 4.0 Frameset, obsolete in HTML5.
<noframes>...</noframes>(deprecated)
- Contains normal HTML content for user agents that don't support
<frame>
elements. - Standardized in HTML 4.0 Transitional, obsolete in HTML5.
<iframe>...</iframe>
- An inline frame places another HTML document in a frame. Unlike an
<object>
element, an<iframe>
can be the "target" frame for links defined by other elements, and it can be selected by the user agent as the focus for printing, viewing its source, and so on. - The content of the element is used as alternative text to be displayed if the browser does not support inline frames.
- First introduced by Microsoft Internet Explorer in 1997, standardized in HTML 4.0 Transitional, allowed in HTML5.
longdesc
attribute
In HTML, longdesc
is an attribute used within the <image>
, <frame>
, or <iframe>
elements. It is supposed to be a URL[note 8] to a document that provides a long description for the image, frame, or iframe in question.[48] Note that this attribute should contain a URL, and not – as is commonly mistaken – the text of the description itself.
longdesc
was designed to be used by screen readers to display image information for computer users with accessibility issues, such as the blind or visually impaired, and is widely implemented by both web browsers and screen readers.[49] Some developers object that
[50] it is actually seldom used for this purpose because there are relatively few authors who use the attribute and most of those authors use it incorrectly; thus, they recommend deprecating longdesc
.[51] The publishing industry has responded, advocating the retention of longdesc
.[52]
Example
<img src="Hello.jpg" longdesc="description.html">
Content of description.html
:
<br />
<p>This is an image of a two-layered birthday cake.</p>
...
Linking to the long description in the text
Since very few graphical browsers support making the link available natively (Opera and iCab being the exceptions), it is useful to include a link to the description page near the <img>
element whenever possible, as this can also aid sighted users.
Example
<img src="Hello.jpg" longdesc="description.html" /> [<a href=
"description.html" title="long description of the image">D</a>]
Historic elements
The following elements were part of the early HTML developed by Tim Berners-Lee from 1989–91; they are mentioned in HTML Tags, but deprecated in HTML 2.0 and were never part of HTML standards.
<listing>...</listing>(deprecated)
- This element displayed the text inside the tags in a monospace font and without interpreting the HTML. The HTML 2.0 specification recommended rendering the element at up to 132 characters per line.
- Deprecated in HTML 3.2; obsolete in HTML5.[53]
<plaintext />(deprecated)
<plaintext>
does not have an end tag as it terminates the markup and causes the rest of the document to be parsed as if it were plaintext.<plaintext>
existed in HTML Tags; deprecated in HTML 2.0; invalid in HTML 4.0.<xmp>...</xmp>(deprecated)
- This element displayed the text inside the tags in a monospace font and without interpreting the HTML. The HTML 2.0 specification recommended rendering the element at 80 characters per line.
- Deprecated in HTML 3.2; obsolete in HTML5.[54]
<nextid />(deprecated)
- This element enabled NeXT web designing tool to generate automatic NAME labels for its anchors and was itself automatically generated.[55]
<nextid>
existed in HTML Tags (described as obsolete); deprecated in HTML 2.0; invalid in HTML 3.2 and later.
Non-standard elements
This section lists some widely used obsolete elements, which means they are not used in valid code. They may not be supported in all user agents.
<blink>...</blink>(deprecated)
- Causes text to blink. Introduced in imitation of the ANSI escape codes. Can be done with CSS where supported:
{text-decoration: blink}
(This effect may have negative consequences for people with photosensitive epilepsy;[56] its use on the public Internet should follow the appropriate guidelines.) <blink>
originated in Netscape Navigator and is mostly recognized by its descendants, including Firefox; deprecated or invalid in HTML 2.0 and later. Note that the replacement CSS tag, while standard, is not required to be supported.<marquee>...</marquee>(deprecated)
- Creates scrolling text. Can be done with scripting instead. (This effect may have negative consequences for people with photosensitive epilepsy;[56] its use on the public Internet should follow the appropriate guidelines.) There are three options, including Alternate, Scroll and slide. Scrolldelay can also be added.
<marquee>
originated in Microsoft Internet Explorer; deprecated or invalid in HTML 4.01 and later.<nobr>...</nobr>(deprecated)
- Causes text to not break at end of line, preventing word wrap where text exceeds the width of the enclosing object. Adjacent text may break before and after it. Can be done with CSS:
{white-space: nowrap;}
<nobr>
is a proprietary element which is recognized by most browsers for compatibility reasons; deprecated or invalid in HTML 2.0 and later.<noembed>...</noembed>(deprecated)
- Specifies alternative content, if the embed cannot be rendered. Replaced by the content of the
<embed>
or<object>
element.
Comments
<!-- A Comment -->
A comment in HTML (and related XML, SGML and SHTML) uses the same syntax as the SGML comment or XML comment, depending on the doctype.
Unlike most HTML tags, comments do not nest.
The markup <!--Xbegin<!--Y-->Xend-->
will yield the comment Xbegin<!--Y
and the text Xend-->
after it.
Comments can appear anywhere in a document, as the HTML parser is supposed to ignore them no matter where they appear so long as they are not inside other HTML tag structures.
Comments can even appear before the doctype declaration; no other tags are permitted to do this.
However, not all browsers and HTML editors are fully compliant with the HTML syntax framework and may do unpredictable things under some syntax conditions. Defective handling of comments only affects about 5% of all browsers and HTML editors in use (IE6 accounting for most of this high percentage). Even then only certain versions are affected by comment mishandling issues.
There are a few compatibility quirks involving comments:
- Placing comments – or indeed any characters except for white-space – before the doctype will cause Internet Explorer 6 to use quirks mode for the HTML page. None of its enclosed contents are processed.
- For compatibility with some pre-1995 browsers, the contents of
<style>
and<script>
elements are still sometimes surrounded by comment delimiters. - The BlueGriffon HTML editor, in versions 1.7.x makes comments that are not embedded in the syntax structure
<style> ... {comment tags} ...</style>
show up on screen. Other HTML editors may have this same defect.
Notes
- ^ "Document" may refer interchangeably to either a file stored on a computer filesystem, usually on disk, or to a document delivered across the Web by HTTP. Such documents may equally be copies of disk files stored on the web server, or they may be generated on demand.
- ^ Document Object Model is now a formalized specification by the W3C.[1] It defines an interface to this internal model, rather than the internal model itself. Early web browsers used their own internal representation that bore little relation to the DOM. The term "document tree" has also been applied.[2] However for the purpose here, of explaining the difference between a document of tags and a parsed model of elements, it is convenient to use the term DOM throughout.
- ^ The term "web browser" here is used for simplicity. It does of course include other sorts of web user agent, such as search engine web crawlers, automatic news-feed retrievers etc.
- ^ HTML 4.01 is one of a small number of well-known HTML DTDs. It is chosen here as the best illustrative example, although the same behavior applies to the other W3C-published DTDs for HTML.
- ^ A macro-like feature of DTDs may still be used within XML.
- ^ One minor point is that XML, even after the DOM interface, is case-sensitive.[6]
- ^ However, see
<object>
for the inevitable exception. - ^ Strictly an IRI, not a URL; although URLs are a subset of IRIs.
References
- ^ "Document Object Model (DOM) Current Version". W3C. 26 July 2016.
- ^ "Definitions – Document tree". Cascading Style Sheets Level 2 Revision 1 (CSS 2.1) Specification. W3C. 7 June 2011.
{{cite web}}
:|section=
ignored (help) - ^ "§3.2.1 Elements". HTML 4.01 Specification. W3C. 24 December 1999.
{{cite web}}
:|section=
ignored (help) - ^ "§3.1 Introduction to SGML". HTML 4.01 Specification. W3C. 24 December 1999.
{{cite web}}
:|section=
ignored (help) - ^ "HTML 4.01, §21, Document Type Definition". W3C. 24 December 1999.
- ^ "§1.3. XHTML and the HTML DOM". Document Object Model (DOM) Level 2 HTML Specification. W3C. 9 January 2003.
{{cite web}}
:|section=
ignored (help) - ^ a b "§7.5.3 Block-level and inline elements". HTML 4.01 Specification. W3C. 24 December 1999.
{{cite web}}
:|section=
ignored (help) - ^ Mark Newhouse (27 September 2002). "CSS Design: Taming Lists". A List Apart.
- ^ XHTML 1.0 §4.2
- ^ XML 1.0 (The ability to produce additional elements is part of the eXtensibility in the acronym.)
- ^ XML 1.0 §5.1
- ^ XHTML 1.1 §A
- ^ "HTML & CSS". W3C. 2013.
- ^ "Appendix D. Default style sheet for HTML 4". Cascading Style Sheets Level 2 Revision 1 (CSS 2.1) Specification. W3C. 7 June 2011.
- ^ HTML 4.01 §14.1
- ^ Ferraiolo, J. Fujisawa, J, and Jackson, D (editors) (2003-01-14). "Scalable Vector Graphics (SVG) 1.1 Specification, §2.3 Options for using SVG in Web pages". W3C. Retrieved 2009-03-25.
{{cite web}}
:|author=
has generic name (help)CS1 maint: multiple names: authors list (link) - ^ HTML 4.01 §12.3
- ^ HTML 4.01 §14.3.2
- ^ HTML 4.01 §18
- ^ CSS §1.1
- ^ "4.4 Grouping content – HTML5". HTML5: A vocabulary and associated APIs for HTML and XHTML – W3C Recommendation. World Wide Web Consortium. 28 October 2014. 4.4.8 The dl element. Retrieved 16 August 2015.
- ^ "Lists in HTML documents". HTML 4.01 Specification – W3C Recommendation. World Wide Web Consortium. 24 December 1999. 10.3 Definition lists: the DL, DT, and DD elements. Retrieved 2 May 2015.
- ^ W3C (5 April 2011). "HTML5: A Vocabulary and Associated APIs for HTML and XHTML, W3C Working Draft".
{{cite web}}
: CS1 maint: numeric names: authors list (link). - ^ HTML 4.01, W3.org, retrieved 2012-03-26
- ^ HTML 4 for dummies, 5th edition, 2005, By Ed Tittel, Mary C. Burmeister, p. 96.
- ^ "ServerWriter -- /Provider". www.w3.org.
- ^ "HTML 5.2". w3.org.
- ^ 4.6 Text-level semantics — The b element, Developers.whatwg.org, retrieved 2012-03-26
- ^ 4.6 Text-level semantics — The i element, Developers.whatwg.org, retrieved 2012-03-26
- ^ 4.6 Text-level semantics — The u element, Developers.whatwg.org, retrieved 2012-03-26
- ^ 4.6 Text-level semantics — The small element, Developers.whatwg.org, retrieved 2012-03-26
- ^ 4.6 Text-level semantics — The s element, Developers.whatwg.org, retrieved 2012-03-26
- ^ a b 11 Obsolete features — HTML5, W3.org, retrieved 2012-03-26
- ^ "". MDN Web Docs.
- ^ "HTML
Tag" . www.quackit.com. - ^ ". MDN Web Docs.
- ^ ". MDN Web Docs.
- ^ ". MDN Web Docs.
- ^ "". MDN Web Docs.
- ^ ". MDN Web Docs.
- ^ Jennifer Kyrnin
<embed>
- ^ W3Schools about
<embed>
- ^ The alt attribute's text cannot be styled with markup; as a result, other methods of alternative text presentation, such as Fahrner Image Replacement, have been devised to accommodate situations in which the coder wishes styled text to be displayed if images are disabled in a user's browser.
- ^ "What's New in Internet Explorer 8 – Accessibility and ARIA". MSDN. Microsoft. Retrieved 2009-07-22.
- ^ Bug 5566 – ALT attribute value sometimes not displayed when image is missing, Bugs.webkit.org, retrieved 2012-03-26
- ^ WWW-Talk Jan-Mar 1993: proposed new tag: IMG, 1997.webhistory.org, retrieved 2012-03-26
- ^ "Are frames accessible?".
...frames do present additional usability challenges that are unique to users with disabilities, particularly those who use screen readers.
- ^ "Objects, Images, and Applets". W3C. Retrieved 2008-12-20.
- ^ "InState Longdesc". Retrieved 2011-09-05.
- ^ "Creating Accessible Images". WebAim. Retrieved 2008-12-20.
- ^ Longdesc usage - WHATWG Wiki, Wiki.whatwg.org, retrieved 2012-03-26
- ^ "Bug 13461 - Commentary on Issue #30 (longdesc) from the Association of American Publishers". Retrieved 2011-09-05.
- ^ "<listing>". MDN Web Docs.
- ^ "<xmp>". MDN Web Docs.
- ^ "<nextid>: The NeXT ID element (Obsolete)". MDN Web Docs.
- ^ a b Chisholm, Wendy; Vanderheiden, Gregg; Jacobs, Ian (1999-05-05). "Web Content Accessibility Guidelines 1.0". World Wide Web Consortium. Retrieved 2010-07-20.
Bibliography
HTML standards
- HTML 2.0:
- Berners-Lee, T.; Connolly, D. (November 1995). "Hypertext Markup Language - 2.0 (RFC 1866)". IETF. Retrieved 2009-03-24.
- HTML 3.2:
- Raggett, Dave (1997-01-14). "HTML 3.2 Reference Specification". W3C. Retrieved 2009-03-27.
- HTML 4.01:
- Raggett, Dave; Le Hors, A; Jacobs, I. (1999-12-24). "HTML 4.01 Specification". W3C. Retrieved 2009-03-24. (HTML 4.01 is the updated form of HTML 4.0.)
- XHTML 1.0:
- W3C (2000-01-26). "XHTML 1.0: The Extensible HyperText Markup Language (Second Edition)". W3C. Retrieved 2009-03-24.
{{cite web}}
: CS1 maint: numeric names: authors list (link)
- XHTML 1.1:
- Altheim, M., and McCarron, S. (editors) (2001-05-31). "XHTML 1.1 - Module-based XHTML". W3C. Retrieved 2009-03-25.
{{cite web}}
:|author=
has generic name (help)CS1 maint: multiple names: authors list (link)
Other sources
- HTML Tags:
- Berners-Lee, T. (1992-11-03). "HTML Tags". Retrieved 2009-03-28. (Part of the first published description of HTML.)
- HTML Internet Draft 1.2:
- Berners-Lee, T.; Connolly, D. (June 1993). "Hypertext Markup Language (HTML)" (text). Retrieved 2009-03-28.
- HTML 3.0 Drafts:
- Raggett, Dave (1995-03-24). "HyperText Markup Language Specification Version 3.0 (draft)". Retrieved 2009-04-18. (This is the final draft of HTML 3.0, which expired without being developed further.)
- HTML Tables:
- Raggett, Dave (May 1996). "HTML Tables (RFC 1942)". IETF. Retrieved 2009-03-22.
- XML 1.0:
- Bray, T, Paoli, J, Sperberg-McQueen, CM, Maler, E and Yergeau, F (editors) (2008-11-26). "Extensible Markup Language (XML) 1.0 (Fifth Edition)". W3C. Retrieved 2009-03-20.
{{cite web}}
:|author=
has generic name (help)CS1 maint: multiple names: authors list (link)
- CSS:
- Lie, H.W.; Bos, B. (2008-04-11). "Cascading Style Sheets, level 1 (revised 2008-04-11)". W3C. Retrieved 2009-04-05.
External links
- HTML 4.01 (Dec 24, 1999): elements and attributes
- HTML5 (Oct 28, 2014): elements and attributes