NAME
XML::DOM2::DOM::Element - A library of DOM (Document Object Model) methods for XML Elements.
DESCRIPTION
Provides all the DOM method for XML Elements
METHODS
$element->getFirstChild() =head2 $element->firstChild()
Returns the elements first child in it's children list
$element->getLastChild() =head2 $element->lastChild()
Returns the elements last child in it's children list
$element->getChildIndex( @children )
Return the array index of this element in the parent or the passed list (if there is one).
$element->getChildAtIndex( $index )
Return the element at the specified index (the index can be negative).
$element->getNextSibling() =head2 $element->nextSibling()
Return the next element to this element in the parents child list.
$element->getPreviousSibling() =head2 $element->previousSibling()
Return the previous element to this element in the parents child list.
$element->getChildren() =head2 $element->getChildElements() =head2 $element->getChildNodes()
Returns all the elements children.
$element->getChildrenByName( $name )
Returns all the elements children with that tag name (including namespace prefix).
$element->hasChildren() =head2 $element->hasChildElements() =head2 $element->hasChildNodes()
Returns 1 if this element has children.
$element->getParent() =head2 $element->getParentElement() =head2 $element->getParentNode()
Returns the object of the parent element.
$element->setParent( $element ) =head2 $element->setParentElement( $element )
$element->setParent($parent);
Sets the parent node, used internaly.
$element->getParents() =head2 $element->getParentElements() =head2 $element->getParentNodes() =head2 $element->getAncestors()
Return a list of the parents of the current element, starting from the immediate parent. The
last member of the list should be the document element.
$element->isAncestor( $node )
Returns true if the current element is an ancestor of the descendant element.
$element->isDescendant( $node )
Return true if the crrent element is the descendant of the ancestor element.
$element->getSiblings()
Returns a list of sibling elements.
$element->hasSiblings()
Returns true if the elements has sibling elements.
$element->getElementName() =head2 $element->getElementType() =head2 $element->getType() =head2 $element->getTagName() =head2 $element->getTagType() =head2 $element->getNodeName() =head2 $element->getNodeType()
Return a string containing the name (i.e. the type, not the ID) of an element.
$element->getElementID()
Return a string containing the elements ID (unique identifier string).
$element->getAttribute( $attributeName )
Returns the specified attribute in the element, will return a
serialised string instead of posible attribute object if serialise set.
$element->getAttributes( $serialise, $ns )
Returns a list of attributes in various forms.
$element->getAttributeNames()
Returns a list of attribute names, used internaly.
$element->getAttributeNamesNS( $namespace )
Returns a list of attribute names, used internaly.
$element->getAttributeNamespaces()
Returns a list of attribute names, used internaly.
$element->hasAttribute( $attributeName )
Returns true if this element as this attribute.
$element->hasAttributeNS( $namespace, $attributeName )
Returns true if this attribute in this namespace is in this element.
$element->hasAttributes()
Return true is element has any attributes
$element->setAttribute( $attribute, $value )
Set an attribute on this element, it will accept serialised strings or objects.
$element->removeAttribute( $name )
Remove a single attribute from this element.
$element->removeAttributeNS( $namespace, $name )
Remove a single attribute from this element.
$element->getAttributeNS( $namespace, $name )
Returns an attributes namespace in this element.
$element->setAttributeNS( $namespace, $name, $value )
Sets an attributes namespace in this element.
$element->cdata( $text )
Rerieve and set this elements cdata (non tag cdata form)
$element->hasCDATA()
Return true if this element has cdata.
$element->document()
Return this elements document, returns undef if no document available.
$element->insertBefore( $node, $childNode ) =head2 $element->insertChildBefore( $node, $childNode ) =head2 $element->insertNodeBefore( $node, $childNode ) =head2 $element->insertElementBefore( $node, $childNode )
Inserts a new element just before the referenced child.
$element->insertAfter( $node, $childNode ) =head2 $element->insertChildAfter( $node, $childNode ) =head2 $element->insertElementAfter( $node, $childNode ) =head2 $element->insertNodeAfter( $node, $childNode )
Inserts a new child element just after the referenced child.
$element->insertSiblingAfter( $node )
Inserts the child just after the current element (effects parent).
$element->insertSiblingBefore( $node )
Inserts the child just before the current element (effects parent).
$element->replaceChild( $newChild, $oldChild )
Replace an old child with a new element, returns old element.
$element->replaceElement( $newElement ) =head2 $element->replaceNode( $newElement )
Replace an old element with a new element in the parents context; element becomes orphaned.
$element->removeChild( $child )
Remove a child from this element, returns the orphaned element.
$element->removeElement() =head2 $element->removeNode()
Removes this element from it's parent; element becomes orphaned.
$element->appendChild( $node ) =head2 $element->appendElement( $node ) =head2 $element->appendNode( $node )
Adds the new child to the end of this elements children list.
$element->cloneNode( $deep ) =head2 $element->cloneElement( $deep )
Clones the current element, deep allows all child elements to be cloned.
The new element is an orphan with all the same id's and atributes as this element.
$element->findChildIndex( $child )
Scans through children trying to find this child in the list.
$element->insertAtIndex( $node, $index )
Adds the new child at the specified index to this element.
$element->removeChildAtIndex( $index )
Removed the child at index and returns the now orphaned element.
$element->createChildElement
Not DOM2, creates a child element, appending to current element.
The advantage to using this method is the elements created with $document->createElement create basic element objects or base objects (those specified in the XML base class or it's kin) Elements created with this could offer more complex objects back.
Example: an SVG Gradiant will have stop elements under it, creating stop elements with $document->createElement will return an XML::DOM2::Element create a stop element with $element->createChildElement and it will return an SVG2::Element::Gradiant::Stop object (although both would output the same xml) and t would also prevent you from creating invalid child elements such as a group within a text element.
$element->createChildElement($name, %opts);
AUTHOR
Martin Owens, doctormo@postmaster.co.uk
SEE ALSO
perl(1), XML::DOM2, XML::DOM2::Element
http://www.w3.org/TR/1998/REC-DOM-Level-1-19981001/level-one-core.html DOM at the W3C