XML DOM Create Nodes
Examples
The examples below use the XML file
books.xml.
A function, loadXMLDoc(), in an external JavaScript is used to load the XML file.
Create an
element node
This example uses createElement() to create a new element node, and appendChild() to
add it to a node.
Create an attribute
node using createAttribute
This example uses createAttribute() to create a new attribute node, and
setAttributeNode() to insert it to an element.
Create an attribute
node using setAttribute
This example uses setAttribute() to create a new attribute for an element.
Create a
text node
This example uses createTextNode() to create a new text node, and appendChild() to
add it to an element.
Create a CDATA section node
This example uses createCDATAsection() to create a CDATA section node, and
appendChild() to add it to an element.
Create a
comment node
This example uses createComment() to create a comment node, and appendChild() to
add it to an element.
Create a New Element Node
The createElement() method creates a new element node:
xmlDoc=loadXMLDoc("books.xml");
newel=xmlDoc.createElement("edition");
x=xmlDoc.getElementsByTagName("book")[0];
x.appendChild(newel);
|
Example explained:
- Load "books.xml"
into xmlDoc using loadXMLDoc()
- Create a new element node <edition>
- Append the element node to the first <book> element
Try
it yourself
Loop through and add an element to all <book> elements:
Try
it yourself
Create a New Attribute Node
The createAttribute() is used to create a new attribute node:
xmlDoc=loadXMLDoc("books.xml");
newatt=xmlDoc.createAttribute("edition");
newatt.nodeValue="first";
x=xmlDoc.getElementsByTagName("title");
x[0].setAttributeNode(newatt);
|
Example explained:
- Load "books.xml"
into xmlDoc using loadXMLDoc()
- Create a new attribute node "edition"
- Set the value of the attribute node to "first"
- Add the new attribute node to the first <title> element
Try
it yourself
Loop through all <title> elements and add a new attribute node:
Try
it yourself
Note: If the attribute already exists, it is replaced by the new one.
Create an Attribute Using setAttribute()
Since the setAttribute() method creates a new attribute if the attribute does
not exist, it can be used to create a new attribute.
xmlDoc=loadXMLDoc("books.xml");
x=xmlDoc.getElementsByTagName('book');
x[0].setAttribute("edition","first");
|
Example explained:
- Load "books.xml"
into xmlDoc using loadXMLDoc()
- Set (create) the attribute "edition" with the value "first"
for the first <book> element
Try
it yourself
Loop through all <title> elements and add a new attribute:
Try
it yourself
Create a Text Node
The createTextNode() method creates a new text node:
xmlDoc=loadXMLDoc("books.xml");
newel=xmlDoc.createElement("edition");
newtext=xmlDoc.createTextNode("first");
newel.appendChild(newtext);
x=xmlDoc.getElementsByTagName("book")[0];
x.appendChild(newel);
|
Example explained:
- Load "books.xml"
into xmlDoc using loadXMLDoc()
- Create a new element node <edition>
- Create a new text node with the text "first"
- Append the new text node to the element node
- Append the new element node to the first <book> element
Try
it yourself
Add an element node, with a text node, to all <book> elements:
Try
it yourself
Create a CDATA Section Node
The createCDATASection() method creates a new CDATA section node.
xmlDoc=loadXMLDoc("books.xml");
newCDATA=xmlDoc.createCDATASection("Special Offer & Book Sale");
x=xmlDoc.getElementsByTagName("book")[0];
x.appendChild(newCDATA);
|
Example explained:
- Load "books.xml"
into xmlDoc using loadXMLDoc()
- Create a new CDATA section node
- Append the new CDATA node to the first <book> element
Try
it yourself
Loop through, and add a CDATA section, to all <book> elements:
Try
it yourself
Create a Comment Node
The createComment() method creates a new comment node.
xmlDoc=loadXMLDoc("books.xml");
newComment=xmlDoc.createComment("Revised March 2008");
x=xmlDoc.getElementsByTagName("book")[0];
x.appendChild(newComment);
|
Example explained:
- Load "books.xml"
into xmlDoc using loadXMLDoc()
- Create a new comment node
- Append the new comment node to the first <book> element
Try
it yourself
Loop through, and add a comment node, to all <book> elements:
Try
it yourself
Whether you're new to XML or already an advanced user, the user-friendly views
and powerful entry helpers, wizards, and debuggers in XMLSpy are designed to
meet your XML and Web services development needs from start to finish.
- XML editor
- Graphical XML Schema / DTD editors
- XSLT 1.0/2.0 editor, debugger, profiler
- XQuery editor, debugger, profiler
- Support for Office Open XML (OOXML)
- Graphical WSDL editor & SOAP debugger
- Java, C#, C++ code generation
- And much more!
Download a free 30-day trial today!
Click to see a demo!
Learn what’s new in v2008
 |
|
Get Your Diploma!
W3Schools' Online Certification Program is the perfect solution for busy
professionals who need to balance work, family, and career building.
The HTML Certificate is for developers who want to document their knowledge of HTML, XHTML, and CSS.
The ASP Certificate is for developers who want to document their knowledge of ASP, SQL, and ADO.
|
|