Websiteentwicklung: XHTML: Elementreferenz
Im Folgenden gibt es eine tabellarische Zusammenfassung der Module von XHTML 1.1 und XHTML+RDFa.
Übersicht Kurzschreibweise
BearbeitenEs wird jeweils eine Kurzschreibweise verwendet, mit folgenden Bedeutungen, wobei Buchstaben wie a, b, c etc jeweils Ausdrücke repräsentieren:
- a ?
- Kein oder ein Ausdruck a ist erlaubt.
- a +
- Ein oder mehr Ausdrücke a sind erforderlich
- a *
- Kein, ein oder mehr Ausdrücke a sind erlaubt
- a , b
- a gefolgt von b ist erforderlich
- a | b
- Es ist erforderlich, entweder a oder b anzugeben
- a - b
- a ist erlaubt, aber ohne Element von b
- Klammern ()
- Der Inhalt der Klammer bildet einen Ausdruck. Unterausdrücke darin werden zu einem Ausdruck ausgewertet, bevor der Klammerausdruck ausgewertet wird
- Erweiterung vordefinierter Elemente
- Einige Attribute erweitern den Funktionsumfang von bereits definierten Attributen durch weitere Attribute, dies wird gekennzeichnet durch den Elementnamen gefolgt von einem &
- Erforderliche Attribute
- Falls ein Attribut für ein Element erforderlich ist, ist hinter den Attributnamen ein * gesetzt
- Attributwerte
- Mögliche Attributewerte sind in Klammern hinter dem Attributnamen angegeben
- Spezifische Attributwerte
- Manchmal bestehen die Attributwerte nur aus spezifischen Zeichenfolgen. Diese Werte sind in Anführungszeichen angegeben, gegebenenfalls bei mehreren mit | separiert. Falls eine Voreinstellung vorhanden ist, ist an diesen Wert ein * angehängt. Gibt es nur einen festen Wert, so ist dieser nach einem = in Anführungszeichen angegeben.
<!-- Das ist ein Kommentar -->
Kollektionsname | Attribute |
---|---|
Kernattribute (Core) | xml:space ("default"* | "preserve"), class (CDATA), id (ID), title (CDATA) |
Sprachattribute (I18N) | dir ("ltr" | "rtl"), xml:lang (CDATA) |
Ereignisse (Event) | onclick (Script), ondblclick (Script), onmousedown (Script), onmouseup (Script), onmouseover (Script), onmousemove (Script), onmouseout (Script), onkeypress (Script), onkeydown (Script), onkeyup (Script) |
Stilvorlage (Style; veraltet) | style (CDATA) |
Allgemein verwendbare Attribute (Common) | Core + Event + I18N + Style |
Kernmodule
BearbeitenDiese Module sind in allen Varianten von XHTML verfügbar.
html
ist das Wurzelelement eines XHTML-Dokumentes.
Element | Attribute | Minimales Inhaltsmodell |
---|---|---|
html | I18N, id (ID), version (CDATA), xmlns (URI = "http://www.w3.org/1999/xhtml") | head, body |
head | I18N, id (ID), profile (URIs) | title |
title | I18N, id (ID) | PCDATA |
body | Common | (Heading | Block | List)* |
Textmodul
BearbeitenElement | Attribute | Minimales Inhaltsmodell |
---|---|---|
abbr | Common | (PCDATA | Inline)* |
acronym | Common | (PCDATA | Inline)* |
address | Common | (PCDATA | Inline)* |
blockquote | Common, cite (URI) | (Heading | Block | List)* |
br | Core | leer, kein Inhalt |
cite | Common | (PCDATA | Inline)* |
code | Common | (PCDATA | Inline)* |
dfn | Common | (PCDATA | Inline)* |
div | Common | (PCDATA | Flow)* |
em | Common | (PCDATA | Inline)* |
h1 | Common | (PCDATA | Inline)* |
h2 | Common | (PCDATA | Inline)* |
h3 | Common | (PCDATA | Inline)* |
h4 | Common | (PCDATA | Inline)* |
h5 | Common | (PCDATA | Inline)* |
h6 | Common | (PCDATA | Inline)* |
kbd | Common | (PCDATA | Inline)* |
p | Common | (PCDATA | Inline)* |
pre | Common | (PCDATA | Inline)* |
q | Common, cite (URI) | (PCDATA | Inline)* |
samp | Common | (PCDATA | Inline)* |
span | Common | (PCDATA | Inline)* |
strong | Common | (PCDATA | Inline)* |
var | Common | (PCDATA | Inline)* |
Dazu Werden einige Elemente zu Gruppen zusammengefaßt und mit einer Bezeichnung versehen:
- Überschriften (Heading)
- h1 | h2 | h3 | h4 | h5 | h6
- Blockelemente (Block)
- address | blockquote | div | p | pre
- Inzeilige, Phrasenelemente (Inline)
- abbr | acronym | |br | cite | code | dfn | em | kbd | q | samp | span | strong | var
- Laufender Inhalt (Flow)
- Heading | Block | Inline
Andere Module fügen zu den Gruppen bisweilen weitere Elemente hinzu, besonders zu Block und Inline. In diesem Wiki-Buch werden Heading, Block und das noch folgende List gemeinsam als Blockelemente bezeichnet.
Element | Attribute | Minimales Inhaltsmodell |
---|---|---|
a | Common, Attribut accesskey (Zeichen), charset (Zeichenkodierung), Attribut href (URI), hreflang (Sprachkürzel), rel (Verweistyp), rev (Verweistyp), tabindex (Zahl), type (Inhaltstyp) | (PCDATA | Inline - a)* - Auch Nachfahren von a dürfen kein a enthalten |
a
wird zur Gruppe Inline hinzugefügt.
Element | Attribute | Minimales Inhaltsmodell |
---|---|---|
dl | Common | (dt | dd)+ |
dt | Common | (PCDATA | Inline)* |
dd | Common | (PCDATA | Flow)* |
ol | Common | li+ |
ul | Common | li+ |
li | Common | (PCDATA | Flow)* |
Die Elemente werden zur Gruppe List zusammengefaßt. Die Gruppe wird zur Gruppe Flow hinzugefügt. (In diesem Wiki-Buch werden Listen mit zur Gruppe der Blockelemente gerechnet).
Texterweiterung
BearbeitenPräsentationsmodul
BearbeitenElement | Attribute | Minimales Inhaltsmodell |
---|---|---|
b | Common | (PCDATA | Inline)* |
big | Common | (PCDATA | Inline)* |
hr | Common | leer, kein Inhalt |
i | Common | (PCDATA | Inline)* |
small | Common | (PCDATA | Inline)* |
sub | Common | (PCDATA | Inline)* |
sup | Common | (PCDATA | Inline)* |
tt | Common | (PCDATA | Inline)* |
hr
wird zu Block hinzugefügt.
Die anderen zu Inline.
Element | Attribute | Minimales Inhaltsmodell |
---|---|---|
del | Common, cite (URI), datetime (Datum) | (PCDATA | Flow)* |
ins | Common, cite (URI), datetime (Datum) | (PCDATA | Flow)* |
Die Elemente werden zu Inline und Block hinzugefügt. Obwohl die Elemente eigentlich inzeilige Element sind, können sie aufgrund der besonderen Bedeutung auch dort verwendet werden, wo Blockelemente stehen dürfen. Das Inhaltsmodell richtet sich also eigentlich nach dem Elternelement. Entsprechend sollten sie keinen Inhalt enthalten, der im Elternelement nicht erlaubt wäre.
Element | Attribute | Minimales Inhaltsmodell |
---|---|---|
bdo | Core, dir* ("ltr" | "rtl"), xml:lang | (PCDATA | Inline)* |
Das Element wird zu Inline hinzugefügt.
Aufgeführt ist hier das komplette Formularmodul, alternativ gibt es etwa für eine Basis-Variante von XHTML1.1 für Mobiltelephone ein Basis-Formularmodul, auf welches hier nicht weiter eingegangen wird.
Element | Attribute | Minimales Inhaltsmodell |
---|---|---|
form | Common, accept (Inhaltstyp), accept-charset (Zeichenkodierung), action* (URI), method ("get"* | "post"), name (CDATA), enctype (Inhaltstyp) | (Heading | List | Block - form | fieldset)+ |
input | Common, accept (Inhaltstyp), accesskey (Zeichen), alt (CDATA), checked ("checked"), disabled
("disabled"), maxLänge (Zahl), name (CDATA), readonly ("readonly"), size (Zahl), src (URI), tabindex (Zahl), type ("text"* | "password" | "checkbox" | "button" | "radio" | "submit" | "reset" | "file" | "hidden" | "image"), value (CDATA) |
leer, kein Inhalt |
select | Common, disabled ("disabled"), multiple ("multiple"), name (CDATA), size (Zahl), tabindex (Zahl) | (optgroup | option)+ |
option | Common, disabled ("disabled"), label (CDATA), selected ("selected"), value (CDATA) | PCDATA |
textarea | Common, accesskey (Zeichen), cols* (Zahl), disabled ("disabled"), name (CDATA), readonly ("readonly"), rows* (Zahl), tabindex (Zahl) | PCDATA |
button | Common, accesskey (Zeichen), disabled ("disabled"),
name (CDATA), tabindex (Zahl), type ("button" | "submit"* | "reset"), value (CDATA) |
(PCDATA | Heading | List | Block - Form | Inline - Formctrl)* |
fieldset | Common | (PCDATA | legend | Flow)* |
label | Common, accesskey (Zeichen), for (Fragmentidentifizierer) | (PCDATA | Inline - label)* |
legend | Common, accesskey (Zeichen) | (PCDATA | Inline)* |
optgroup | Common, disabled ("disabled"), label* (CDATA) | option+ |
Mit dem Modul werden zwei Gruppen von Elementen definiert.
Form: form | fieldset
Formctrl: input | select | textarea | label | button
Form wird zu Block hinzugefügt- Formctrl wird zu Inline hinzugefügt. Elemente von Formctrl sollten offenbar nur als Nachfahren von Form auftreten.
Aufgeführt ist hier das komplette Tabellenmodul, alternativ gibt es etwa für eine Basis-Variante von XHTML1.1 für Mobiltelephone ein Basis-Tabellenmodul, auf welches hier nicht weiter eingegangen wird.
Element | Attribute | Minimales Inhaltsmodell |
---|---|---|
caption | Common | (PCDATA | Inline)* |
table | Common, border (Pixel), cellpadding (Länge), cellspacing (Länge), frame ("void" | "above" | "below" |
"hsides" | "lhs" | "rhs" | "vsides" | "box" | "border"), rules ("none" | "groups" | "rows" | "cols" | "all"), summary (CDATA), width (Länge) |
caption?, ( col* | colgroup* ), (( thead?, tfoot?, tbody+ ) | ( tr+ )) |
td | Common, abbr (CDATA), align ("left" | "center" | "right" | "justify" | "char"), axis (CDATA), char (Zeichen), charoff (Länge), colspan (Zahl), headers (Liste von Fragmentidentifzierern), rowspan (Zahl), scope ("row" | "col" | "rowgroup" | "colgroup"), valign ("top" | "middle" | "bottom" | "baseline") | (PCDATA | Flow)* |
th | Common, abbr (CDATA), align ("left" | "center" | "right" | "justify" | "char"), axis (CDATA), char (Zeichen), charoff (Länge), colspan (Zahl), headers (Liste von Fragmentidentifzierern), rowspan (Zahl), scope ("row" | "col" | "rowgroup" | "colgroup"), valign ("top" | "middle" | "bottom" | "baseline") | (PCDATA | Flow)* |
tr | Common, align ("left" | "center" | "right" | "justify" | "char"), char (Zeichen), charoff (Länge), valign ("top" | "middle" | "bottom" | "baseline") | (td | th)+ |
col | Common, align ("left" | "center" | "right" | "justify" | "char"), char (Zeichen), charoff (Länge), span (Zahl), valign ("top" | "middle" | "bottom" | "baseline"), width (Liste mit Längen) | leer, kein Inhalt |
colgroup | Common, align ("left" | "center" | "right" | "justify" | "char"), char (Zeichen), charoff (Länge), span (Zahl), valign ("top" | "middle" | "bottom" | "baseline"), width (Liste mit Längen) | col* |
tbody | Common, align ("left" | "center" | "right" | "justify" | "char"), char (Zeichen), charoff (Länge), valign ("top" | "middle" | "bottom" | "baseline") | tr+ |
thead | Common, align ("left" | "center" | "right" | "justify" | "char"), char (Zeichen), charoff (Länge), valign ("top" | "middle" | "bottom" | "baseline") | tr+ |
tfoot | Common, align ("left" | "center" | "right" | "justify" | "char"), char (Zeichen), charoff (Länge), valign ("top" | "middle" | "bottom" | "baseline") | tr+ |
table
wird zu Block hinzugefügt.
Element | Attribute | Minimales Inhaltsmodell |
---|---|---|
img | Common, alt* (CDATA), height (Länge), longdesc (URI), name (CDATA), src* (URI), width (Länge) | leer, kein Inhalt |
img
wird zu Inline hinzugefügt.
Element | Attribute | Minimales Inhaltsmodell |
---|---|---|
a& | coords (CDATA), shape ("rect" | "circle" | "poly" | "default") | - |
area | Common, accesskey (Zeichen), alt* (CDATA), coords (CDATA), href (URI), nohref ("nohref"), shape ("rect"* | "circle" | "poly" | "default"), tabindex (Zahl) | leer, kein Inhalt |
img& | usemap (Fragmentidentifizierer oder URI mit Fragmentidentifizierer) | - |
input& | usemap (Fragmentidentifizierer oder URI mit Fragmentidentifizierer) | - |
map | I18N, Events, class (CDATA), id* (ID), title (CDATA) | ((Heading | List | Block) | area)+ |
object& | usemap (Fragmentidentifizierer oder URI mit Fragmentidentifizierer) | - |
map
wird zu Inline hinzugefügt.
Element | Attribute | Minimales Inhaltsmodell |
---|---|---|
img& | ismap ("ismap") | - |
input& | ismap ("ismap") | - |
Element | Attribute | Minimales Inhaltsmodell |
---|---|---|
object | Common , archive (URIs), classid (URI), codebase (URI), codetype (Inhaltstyp), data (URI), declare ("declare"), height (Länge), name (CDATA), standby (CDATA), tabindex (Zahl), type (Inhaltstyp), width (Länge) | (PCDATA | Flow | param)* |
param | id (ID), name* (CDATA), type (Inhaltstyp), value (CDATA), valuetype ("data"* | "ref" | "object") | leer, kein Inhalt |
object
wird zu Inline hinzugefügt, kann zudem auch innerhalb von head
notiert werden.
In letzterem Falle sollte kein Inhalt verwendet werden, der nicht zum Bereich von head
paßt.
Element | Attribute |
---|---|
a& | onblur (Skript), onfocus (Skript) |
area& | onblur (Skript), onfocus (Skript) |
form& | onreset (Skript), onsubmit (Skript) |
body& | onload (Skript), onunload (Skript) |
label& | onblur (Skript), onfocus (Skript) |
input& | onblur (Skript), onchange (Skript), onfocus (Skript), onselect (Skript) |
select& | onblur (Skript), onchange (Skript), onfocus (Skript) |
textarea& | onblur (Skript), onchange (Skript), onfocus (Skript), onselect (Skript) |
button& | onblur (Skript), onfocus (Skript) |
Die Ereignisse gehören zur Attributkollektion Event.
Element | Attribute | Minimales Inhaltsmodell |
---|---|---|
meta | I18N, content* (CDATA), http-equiv (NMTOKEN, XML-Name), id (ID), name (NMTOKEN, XML-Name), scheme (CDATA) | leer, kein Inhalt |
meta
wird als möglicher Inhalt von head
hinzugefügt.
Element | Attribute | Minimales Inhaltsmodell |
---|---|---|
noscript | Common | (Heading | List | Block)+ |
script | charset (Zeichen), defer ("defer"), id (ID), src (URI), type* (Inhaltstyp) | PCDATA |
script
und noscript
werden zu Block und Inline hinzugefügt.
Zusätzlich ist script
auch in head
erlaubt.
Element | Attribute | Minimales Inhaltsmodell |
---|---|---|
style | I18N, id (ID), media (Medientyp), title (CDATA), type* (Inhaltstyp) | PCDATA |
style
ist in head
erlaubt.
style-Attribut-Modul
BearbeitenDies erlaubt die Verwendung des Attributes style als allgemein verwendbares Attribut, oben bereits als solches aufgeführt, gilt allerdings als veraltet.
Element | Attribute | Minimales Inhaltsmodell |
---|---|---|
link | Common, charset (Zeichenkodierung), href (URI), hreflang (Sprachkürzel), media (Medientyp), rel (Verweistyp), rev (Verweistyp), type (Inhaltstyp) | leer, kein Inhalt |
link
ist in head
erlaubt.
Element | Attribute | Minimales Inhaltsmodell |
---|---|---|
base | href* (URI), id (ID) | leer, kein Inhalt |
base
ist in head
erlaubt.
Die Elemente dieses Moduls sind nicht in XHTML 1.0 verfügbar, aber in XHTML 1.1 und XHTML+RDFa.
Elements | Attributes | Minimales Inhaltsmodell |
---|---|---|
ruby | Common | (rb, (rt | (rp, rt, rp))) |
rbc | Common | rb+ |
rtc | Common | rt+ |
rb | Common | (PCDATA | Inline - ruby)* |
rt | Common, rbspan (CDATA) | (PCDATA | Inline - ruby)* |
rp | Common | PCDATA* |
ruby
wird zu Inline hinzugefügt.
Das maximale Inhaltsmodell für ruby
sieht wie folgt aus: ((rb, (rt | (rp, rt, rp))) | (rbc, rtc, rtc?))
Modul für target
BearbeitenDas Attribut dieses Moduls ist in XHTML1.0 strict und XHTML1.1 nicht verfügbar, aber in XHTML1.0 transitional und XHTML+RDFa.
Element | Attribute |
---|---|
a& | target (CDATA) |
area& | target (CDATA) |
base& | target (CDATA) |
link& | target (CDATA) |
form& | target (CDATA) |
Hier ist zwischen XHTML+RDFa 1.0 und 1.1 zu unterscheiden, 1.1 hat ein paar Attribute mehr, diese Einschränkung ist als Bemerkung angegeben.
Attribut | Bemerkung |
---|---|
about (SafeCURIEorCURIEorIRI) | |
content (CDATA) | |
datatype (TERMorCURIEorAbsIRI) | Falls nicht angegeben, ist der Wert 'string' anzunehmen. |
property (TERMorCURIEorAbsIRIs) | |
rel (TERMorCURIEorAbsIRIs) | |
resource (SafeCURIEorCURIEorIRI) | |
rev (TERMorCURIEorAbsIRIs) | |
typeof (TERMorCURIEorAbsIRIs) | |
prefix ( NCName ': ' IRI )+ | Nur in Version XHTML+RDFa 1.1. |
vocab (IRI) | Nur in Version XHTML+RDFa 1.1. Die IRI definiert das Präfix, welches bei CURIEs zu verwenden ist, die ohne Präfix und Doppelpunkt angegeben werden. |
inlist (Wert leer oder "inlist") | Nur in Version XHTML+RDFa 1.1. |
Diese Kollektion wird zu Common hinzugefügt. Zusätzlich fügt XHTML+RDFa 1.1 noch das Attribut lang zu I18N hinzu. Es hat die gleiche Bedeutung wie xml:lang und muß, sofern verwendet, den gleichen Wert wie xml:lang haben.
Weitere Module
BearbeitenDie XHTML1.1-Modularisierung hat einige weitere Module, die weder in XHTML1.1 noch in XHTML+RDFa verwendet werden. Dies sind: Applet-Modul (veraltet), Rahmen-Modul (Frames Module), Modul für eingebettete Rahmen (Iframe Module), Name-Identifikationsmodul (Name Identification Module; veraltet), Altlasten-Modul (Legacy Module; veraltet).