XHTML (Extensible Hypertext Markup Language) is een opmaaktaal voor vooral websites, die de functionaliteit heeft van HTML, maar een striktere syntaxis. Dit omdat HTML gebaseerd is op het flexibele SGML, waar XHTML gebaseerd is op XML, een striktere subset van SGML. Door de striktere syntaxis van XML-documenten kunnen deze makkelijker verwerkt worden door een XML-parser, terwijl SGML-documenten een veel complexere parser nodig hebben. XHTML 1.0 is een W3C-standaard geworden op 26 januari 2000.
Extensible HyperText Markup Language | ||||
---|---|---|---|---|
Voorbeeld van XHTML | ||||
Status | Gepubliceerd | |||
Startjaar | 26 januari 2000 | |||
Auteurs | W3C en WHATWG | |||
Basisstandaarden | HTML | |||
Gerelateerde standaarden | XML | |||
Afkorting | XHTML | |||
Domein | Wereldwijd web | |||
Website | XHTML 1.1 | |||
|
Voordelen van XHTML
XHTML biedt, mits goed gebruikt, enkele voordelen boven HTML. Doordat XML-documenten well-formed moeten zijn, kunnen ze makkelijker geïnterpreteerd worden door useragents. Een correcte XML-parser moet namelijk een fatale error geven als een XML-document niet volledig correct is, terwijl bij SGML-parsers complexe error-correcties worden gedaan. Doordat voor het verwerken van XHTML minder rekenkracht nodig is kan deze ook beter verwerkt worden door useragents met minder rekenkracht, zoals mobiele telefoons en pda's.
Door de modularisatie van XHTML kan XHTML makkelijk uitgebreid worden met nieuwe elementen en attributen. Ook worden hiermee de compatibiliteitsproblemen opgelost die ontstonden door onofficiële uitbreidingen van de HTML-standaard die niet door alle browsers werden ondersteund.
In XHTML kunnen verschillende XML-namespaces gebruikt worden, zo kunnen MathML en Scalable Vector Graphics in een XHTML-document verweven worden.
Verschillen met HTML 4.01
Inhoudelijk
De inhoudelijke verschillen tussen XHTML 1.0 (XHTML 2.0 wordt verderop besproken) en HTML zijn niet groot, dezelfde elementen en attributen zijn te gebruiken. Het grootste verschil tussen XHTML en HTML is dat XHTML well-formed moet zijn, dit houdt in dat:
- Alle elementen moeten gesloten worden
- Incorrect:
<p>Dit is een alinea.<p>Dit is nog een alinea.
- Correct:
<p>Dit is een alinea.</p><p>Dit is nog een alinea.</p>
- Incorrect:
- Ook lege elementen moeten gesloten worden
- Incorrect:
<br>
- Correct:
<br />
- Incorrect:
- Elementen moeten correct genest worden
- Incorrect:
<em><strong>Dit is tekst met nadruk.</em></strong>
- Correct:
<em><strong>Dit is tekst met nadruk.</strong></em>
- Incorrect:
- Attribuutwaarden moeten tussen aanhalingstekens
- Incorrect:
<td rowspan=3>
- Correct:
<td rowspan="3">
- Incorrect:
- Alle elementen en attributen moeten met kleine letters geschreven worden
- Incorrect:
<BODY><P ID="iets">Wikipedia</P></BODY>
- Correct:
<body><p id="iets">Wikipedia</p></body>
- Incorrect:
- Attributen mogen niet geminimaliseerd worden
- Incorrect:
<textarea readonly>READ-ONLY</textarea>
- Correct:
<textarea readonly="readonly">READ-ONLY</textarea>
- Incorrect:
style
- enscript
-elementen zijn#PCDATA
en zullen dus geparset worden. Speciale karakters, zoals<
, moeten gecodeerd worden als entiteit of binnen eenCDATA
blok geplaatst worden- Incorrect:
<script type="application/x-javascript">if (i < j) document.write("kleiner");</script>
- Correct:
<script type="application/x-javascript"><![CDATA[if (i < j) document.write("kleiner");]]></script>
- Incorrect:
Zogenaamde lege elementen zoals <br />
en <hr />
kunnen ook voluit worden geschreven als <br></br>
en <hr></hr>
in XHTML, dit wordt echter sterk afgeraden omdat veel (oudere) browsers hier niet goed mee omgaan en omdat het syntactisch gezien de indruk wekt dat deze elementen iets kunnen bevatten.
Voor de omzetting van HTML naar XHTML zijn programma's ontwikkeld, maar in principe kan dit ook handmatig worden gedaan.
Technisch
Om XHTML 1.0 compatibel te houden met HTML 4.01 mag XHTML 1.0 worden opgestuurd met het mime-type text/html
dat eigenlijk bedoeld is voor HTML. Dit heeft echter enkele nadelen, XHTML die is verstuurd met dit mime-type wordt namelijk gewoon verwerkt als HTML, het document is dan dus eigenlijk invalide HTML 4.01 in plaats van XHTML, zogenaamde tag-soup. XHTML-documenten verstuurd met het correcte application/xhtml+xml
-mime-type worden door sommige browsers, onder andere het veelgebruikte Internet Explorer (tot versie 9)[1], niet ondersteund. Andere browsers zoals Firefox en Chrome ondersteunen dit wel.
Versies van XHTML
XHTML 1.0
XHTML 1.0 was de eerste XHTML-versie en werd een W3C-standaard op 26 januari 2000. XHTML 1.0 is een herformulering van HTML 4.01 in XML met als doel backwards compatible te zijn. Er zijn drie versies van XHTML 1.0:
- XHTML 1.0 Strict, is hetzelfde als HTML 4.01 Strict met XML-regels.
- XHTML 1.0 Transitional, staat sommige afgekeurde elementen en attributen toe die niet in XHTML 1.0 Strict gebruikt mogen worden, zoals
<center>
,<u>
,<strike>
, en<applet>
. - XHTML 1.0 Frameset, staat het gebruik van HTML-frames toe.
XHTML 1.1
XHTML 1.1 is de eerste XHTML-versie die is gebaseerd op de modularisatie van XHTML en zou de basis moeten zijn van toekomstige XHTML-versies. Door deze modularisatie en het niet meer toestaan van het text/html
-mime-type is XHTML 1.1 niet compatibel met XHTML 1.0 en HTML 4.01. XHTML 1.1 heeft ook ondersteuning voor Ruby, een opmaaktaal voor Oost-Aziatische talen.
XHTML 2.0
Deze versie van XHTML 2.0 was in ontwikkeling, maar is nooit een gebruikte standaard geworden. Het zou een volledig nieuwe opmaaktaal zijn en niet zomaar een nieuwe versie. XHTML 2.0 was dan ook niet compatibel met HTML of enig andere versie van XHTML. In 2009 heeft W3C besloten de ontwikkeling van XHTML 2.0 stop te zetten ten gunste van HTML5[2].
De grootste verschillen tussen XHTML 2.0 en XHTML 1.0 waren:
- HTML-forms zouden ingewisseld worden met XForms.
- HTML-frames zouden ingewisseld worden met XFrames.
- De DOM Events zouden ingewisseld worden met XML Events die het XML Document Object Model gebruiken.
- Er werd een nieuw lijsttype geïntroduceerd:
<nl>
was speciaal bedoeld voor het maken van navigaties. - Elk element kon gebruikt worden als een hyperlink, bijvoorbeeld:
<li href="articles.html">Startpagina</li>
. - Elk element kon alternatieve media aangeven met behulp van het
src
attribuut, bijvoorbeeld:<p src="lbridge.jpg" type="image/jpeg">London Bridge</p>
in plaats van<img src="lbridge.jpg" alt="London Bridge" />
. - Naast de kop-elementen
h1
tot en meth6
konden ook deh
- ensection
-elementen gebruikt worden om beter de structuur van de tekst aan te geven. - De lettertype-elementen
<i>
,<b>
en<tt>
zouden afwezig zijn in XHTML 2.0. De enige lettertype-elementen die overblijven zijn<sup>
en<sub>
.
Andere versies van XHTML
- XHTML Basic: een lichte versie van XHTML bedoeld voor veel verschillende useragents.
- XHTML Mobile Profile: een uitbreiding van XHTML Basic door het Open Mobile Alliance speciaal bedoeld voor mobiele telefoons.
Externe link
Wikiwand in your browser!
Seamless Wikipedia browsing. On steroids.
Every time you click a link to Wikipedia, Wiktionary or Wikiquote in your browser's search results, it will show the modern Wikiwand interface.
Wikiwand extension is a five stars, simple, with minimum permission required to keep your browsing private, safe and transparent.