02Geek HTML5 and JavaScript, TypeScript, React, Flash, ActionScript online School
Previous VideoNext Video

XML DOM

XML DOM stands for XML Document Object Model. DOM is designed to be an interface to a tree-based representation of an XML document. In DOM, every XML entity (element, content, comments) is represented by a node object, where a node is a vertex in the XML tree representation. Different programming and scripting languages (such as Javascript, Perl, Java, etc.) that support information management through an XML API, chiefly support the XML DOM API. We will describe the functionality of the DOM API organization and features by looking at a real-world example.

Consider, for example, a corporate aerospace giant that has a hierarchical employee structure: nodes represent employees, and connecting tree edges (lines) indicate immediate supervisor and subordinates.

A DOM Interface provides an API that can be invoked by the user's program, and it is used to recursively traverse the XML document tree. It has certain standard, flexible API methods such as:

firstSibling(,) lastSibling(,) nextSibling(,) parent(,) firstChild(,) lastChild(,) and nextChild() among others. We shall now see how these APIs can be used to navigate the XML document. As is apparent, this is a very general API: the programmer doesn't need to know beforehand the number of elements, nested elements, etc. in the XML document.

Consider in particular the node representing the employee whose title is "VP Research & Development." In this node context, the above-mentioned API would return the following results, by traversing the tree in downward or upward direction, depending on the requirement:

firstSibling(): "VP Operations"

lastSibling(): "VP Business & Management"

nextSibling(): "VP Business & Management"

parent(): "President & CEO"

firstChild(): "PE Research & technology"

lastChild(): "PE Deployment"

nextChild(): (Depends on context)

To illustrate these results, note that the DOM internally maintains a pointer or marker to determine which node of the XML DOM tree is the current one. All the above operations return values relative to the current position of the pointer.

The DOM model is an old model found in early literature describing the invention of XML and related standards. Modern day XML-parsing standards have moved ahead, but we are learning about the DOM since there is a very large code-base out there in terms of XML language libraries and client code. DOM, in its heyday, had a huge following and is still the most general API around.

Ready to Level Up Your Skills?

Join thousands of learners on 02GEEK and start your journey to becoming a coding expert today!

Enroll Now for Free!

Overview and Context of XML

We will learn about the historical perspective and overview of the XML standard. The main focus is on Information organization and cross platform usage

12:47

XML Elements

The first step in learning about how XML documents are structured is to get familiar with elements, the basic components of an XML document.

08:22

XML Nested Elements

Nested elements allow for complex data to be represented effortlessly in an XML document.

09:19

Attributes

Attribute-value pairs are an alternative to nesting of elements in an XML document. We'll see the pros and cons of this feature

08:12

More Then Just Leftovers

Comments, White-space, Special characters, Version Information and Parser by-passing content; we discuss what these constructs are and how to use them effectively

13:54

XML Validation

XML documents should be well formed structure- and content-wise for applications to be configured and behave properly. We discuss an analogy with a real life scenario to highlight the point

08:17

E4X – ActionScript 3.0

We describe the importance and beneficial features of E4X library, and why it should be used in browsers at the earliest

24:56

XML DOM

An XML document is often pictured as an inverted nodes (elements) tree and connected nodes have a relation between them. DOM allows the program to traverse and retrieve these related nodes.

11:12

JavaScript

We describe the basic syntax of Javascript to load XML documents in client-side applications

13:51

Looping XML

We describe the looping constructs of PHP scripting language and how they can be used to parse and render XML information in client software

14:19

XML as a Remote

We describe the utility of XML for the modern web, especially when there's a plethora of programming languages and platforms and how XML builds several bridges

09:19

Loading XML in PHP

We describe how to load XML documents into server side applications in the PHP scripting language

04:57

Elements and Attributes in PHP

We describe how to access elements and attribute values while processing XML content via PHP scripts in server-side software

04:44

foreach

We describe the foreach looping construct in PHP and also how it can be used to process XML documents in server-side software

07:01

PHP XML compare

We describe how to compare XML document components and content in different documents having the same syntax

05:08

Modifying XML

We describe how to modify the content of XML documents in PHP : insertion/deletion/update operations in server-side applications

08:34