Web Science/Part1: Foundations of the web/Web content/Working with XML/script

In the previous lesson we have seen several requirements that call for separation of content proper and structural or layout information. In this lesson, I will show you how to work with the previous XML file such that it becomes easy to generate structure and/or layout.

Let us first rephrase the core ideas of XML:
 * 1) Markup pieces of content by understandable "parentheses", e.g. Bobby McFerring, "  "  is markup, "Bobby McFerring" is content (problem 2)
 * 2) Allow new applications, e.g. multimedia display instead of text display, to use new markup (problem 3)
 * 3) Allow for nesting of markup such that larger pieces of content may be treated in a meaningful way, e.g.  "  Bobby McFerring  ...  Koblenz ... " (problem 2)
 * 4) Simplify tools by having some simple rules (problem 4):
 * 5) each opening tag like " " requires a corresponding closing tag " "
 * 6) proper nesting of markup: "  Bobby McFerring  ...  Koblenz  " is allowed; "  Bobby McFerring  ...  Koblenz  " is disallowed
 * 7) Each XML document comes with a preamble specifying the character enconding and XML version used, i.e. most often now: "" allowing for internationalization (problem 5)

An XML document that follows these rules is called "well-formed". You can check the well-formedness of a document by XML validators, such as http://www.w3schools.com/xml/xml_validator.asp

Implications that arise from these rules are that:
 * Properly nested Markup gives us a data structure: a DOM tree
 * DOM tree can be navigated recursively by different applications and repurposed for different types of devices and device sizes (problem 1)

Let's look back out our running example (unfortunately I have not found a DOM viewer without installation that shows the DOM tree correctly. Below is a pretty print of the XML code, but not a proper DOM tree view, my previous uploads in the place used http://software.hixie.ch/utilities/js/live-dom-viewer/ but it delivers a buggy tree, e.g. tracktitles not being correctly sorted beneath tracks. Here is the pretty print



And here is the buggy DOM Tree

[]

Let us assume some simple rules that map our element names as follows (some of my wikientry is not displayed !!!)

Then executing a corresponding transformation gives us:

Or using our shorthand description:

The shorthand notation is actually an example of HTML, a piece of Hypertext Markup Language as it is used in the Web. As you note this, you may also recognize that HTML, at least in its version of 4.0 and higher, is actually well-formed XML. Just like our description of records that we started with is well-formed XML. Hence, XML is not one language for structuring data and content, it is actually a meta-language that allows you to come up with infinitely many different languages for structuring data and content. In fact, you can even do it in other encodings than Latin characters, say Kanji or Arabic.

What you may have observed further is that the kind of mapping we have shown based on mapping elements onto new elements is awkward as it requires very strictly observing a certain order of XML elements in the source file. However, you can program a better transformation tool, use a generic tool like AWK or you can use existing tools for manipulating XML, such as XPath, XQuery, XSL (eXtensible Stylesheet Language) consisting of XSLT (eXtensible Stylesheet Language Transformation) and XSL FO (XSL Formatting Objects). We do not go into the details of all these tools as this would require a whole course of its own, but for you it is important to know that such languages and tools exist and you can dig out their description whenever you have a problem in this direction and build your solution based on standardized mechanisms.

The core lesson to be learned about XML here is that XML-based markup gives you a very flexible handle for:
 * selecting content
 * repurposing content
 * reformatting content

What have we not considered here?
 * Conformance of a particular XML document to a schema prescription, e.g. DTD https://en.wikipedia.org/wiki/Document_type_definition or XML Schema https://en.wikipedia.org/wiki/XML_schema
 * Many other (infinitely many) XML applications
 * Interactive XML formats
 * "Infinitely" long streams, i.e. streaming of video, audio, other data...

What we will show you next are some details about HTML and about formatting HTML pages with HTML and Cascading Style Sheets before we then go towards multimedia.