Mink Machine

The closure of XHTML elements

If you have followed the crowd and abandoned HTML for XHTML, you may have noticed that some elements need to be closed in your markup. The reason is that XHTML is simply a reformulation of HTML in XML syntax. It’s a subtle but very significant difference between HTML and XHTML.

The MIME type of a document is the only thing that controls whether it is HTML or XHTML. Since browsers don’t fully support XML mode, full XHTML processing is not an option. This leads to markup being served as “text/html” whether you call it XHTML or not.

Unlike CSS, there is no shorthand notion in HTML. Consider the following code:

<img src="ferret.jpg" alt="ferret" />

The slash at the end closes the element. But the following is not valid:

<script src="coolstuff.js" type="text/javascript" />

Neither is this:

<div id="primary" />

The self-closing slash character is interpreted as an attribute in the markup and ignored (since it’s not a legal attribute name). This means that the self-closed div actually becomes an opening tag without a closing tag.

So why does the self-closed img element work? It is because the HTML DTD states:

<!ELEMENT IMG – O EMPTY — Embedded image –>

As you can see, it allows for empty content. On the other hand, div elements are not allowed to have empty content.

This is just the tip of the iceberg. For more information, have a look at the infamous Appendix C of the XHTML 1.0 standard.

Comments

No comments yet.

Post a comment

Your email address will not be published. Required fields are marked *

Featured stories

On the Trans-Siberian

"Since the toilets were locked during the seven hour stop, we had to bribe the provodnitsas to use the facilities. Then came the Mongols."

Conquering Machu Picchu

"A life-long dream came true this morning, as I stood upon the mountain looking down at Machu Picchu. I felt like some strange mix between Indiana Jones and a small boy, gazing down upon the final treasure of the Incas."

The dark days of Sarajevo

"The city survived on the edge of annihilation and has started to recover, but the stone walls still seem to cry out in lament of all the horrible things they have seen."

A journey through Iran

"I woke up freezing on a Persian rug with aching back. Behind a corner I saw the damned rooster that kept me awake during many hours."

Getting lost in Yazd

"Navigating on random while surrounded by staring old men, pointing their crooked fingers at the Godzilla Viking in surprise. It feels like I’m walking around in Mos Eisley."

The lakes of Lombardy

"The town of Como, largest settlement around Lake Como, attracts a lot of people with big wallets. But I preferred to take the funicular up the mountain to the Brunate region, where you get a much better view of the lake."