XML DOM Tutorial on DOM Node Object

node interface is the primary datatype for the entire document object model. the node is used to represent a single xml element in the entire document tree.

a node can be any type that is an attribute node, a text node or any other node. the attributes nodename, nodevalue and attributes are included as a mechanism to get at node information without casting down to the specific derived interface.

attributes

the following table lists the attributes of the node object −

attribute type description
attributes namednodemap this is of type namednodemap containing the attributes of this node (if it is an element) or null otherwise. this has been removed. refer specs
baseuri domstring it is used to specify absolute base uri of the node.
childnodes nodelist it is a nodelist that contains all children of this node. if there are no children, this is a nodelist containing no nodes.
firstchild node it specifies the first child of a node.
lastchild node it specifies the last child of a node.
localname domstring it is used to specify the name of the local part of a node. this has been removed. refer specs.
namespaceuri domstring it specifies the namespace uri of a node. this has been removed. refer specs
nextsibling node it returns the node immediately following this node. if there is no such node, this returns null.
nodename domstring the name of this node, depending on its type.
nodetype unsigned short it is a code representing the type of the underlying object.
nodevalue domstring it is used to specify the value of a node depending on their types.
ownerdocument document it specifies the document object associated with the node.
parentnode node this property specifies the parent node of a node.
prefix domstring this property returns the namespace prefix of a node. this has been removed. refer specs
previoussibling node this specifies the node immediately preceding the current node.
textcontent domstring this specifies the textual content of a node.

node types

we have listed the node types as below −

  • element_node
  • attribute_node
  • entity_node
  • entity_reference_node
  • document_fragment_node
  • text_node
  • cdata_section_node
  • comment_node
  • processing_instruction_node
  • document_node
  • document_type_node
  • notation_node

methods

below table lists the different node object methods −

s.no. method & description
1 appendchild(node newchild)

this method adds a node after the last child node of the specified element node. it returns the added node.

2 clonenode(boolean deep)

this method is used to create a duplicate node, when overridden in a derived class. it returns the duplicated node.

3 comparedocumentposition(node other)

this method is used to compare the position of the current node against a specified node according to the document order. returns unsigned short, how the node is positioned relatively to the reference node.

4

getfeature(domstring feature, domstring version)

returns the dom object which implements the specialized apis of the specified feature and version, if any, or null if there is no object. this has been removed. refer specs.

5

getuserdata(domstring key)

retrieves the object associated to a key on this node. the object must first have been set to this node by calling the setuserdata with the same key. returns the domuserdata associated to the given key on this node, or null if there was none. this has been removed. refer specs.

6

hasattributes()

returns whether this node (if it is an element) has any attributes or not. returns true if any attribute is present in the specified node else returns false. this has been removed. refer specs.

7 haschildnodes()

returns whether this node has any children. this method returns true if the current node has child nodes otherwise false.

8 insertbefore(node newchild, node refchild)

this method is used to insert a new node as a child of this node, directly before an existing child of this node. it returns the node being inserted.

9 isdefaultnamespace(domstring namespaceuri)

this method accepts a namespace uri as an argument and returns a boolean with a value of true if the namespace is the default namespace on the given node or false if not.

10 isequalnode(node arg)

this method tests whether two nodes are equal. returns true if the nodes are equal, false otherwise.

11

issamenode(node other)

this method returns whether current node is the same node as the given one. returns true if the nodes are the same, false otherwise. this has been removed. refer specs.

12

issupported(domstring feature, domstring version)

this method returns whether the specified dom module is supported by the current node. returns true if the specified feature is supported on this node, false otherwise. this has been removed. refer specs.

13 lookupnamespaceuri(domstring prefix)

this method gets the uri of the namespace associated with the namespace prefix.

14 lookupprefix(domstring namespaceuri)

this method returns the closest prefix defined in the current namespace for the namespace uri. returns an associated namespace prefix if found or null if none is found.

15 normalize()

normalization adds all the text nodes including attribute nodes which define a normal form where structure of the nodes which contain elements, comments, processing instructions, cdata sections, and entity references separates the text nodes, i.e, neither adjacent text nodes nor empty text nodes.

16 removechild(node oldchild)

this method is used to remove a specified child node from the current node. this returns the node removed.

17 replacechild(node newchild, node oldchild)

this method is used to replace the old child node with a new node. this returns the node replaced.

18

setuserdata(domstring key, domuserdata data, userdatahandler handler)

this method associates an object to a key on this node. the object can later be retrieved from this node by calling getuserdata with the same key. this returns the domuserdata previously associated to the given key on this node. this has been removed. refer specs.