w3schools
Search W3Schools :  
  
HOME HTML CSS XML JAVASCRIPT ASP PHP SQL MORE...   References Examples Forum About

XML DOM Replace Nodes

« Previous Next Chapter »

The replaceChild() method replaces a specified node.

The nodeValue property replaces text in a text node.


Examples

The examples below use the XML file books.xml.
A function, loadXMLDoc(), in an external JavaScript is used to load the XML file.

Replace an element node
This example uses replaceChild() to replace the first <book> node.

Replace data in a text node
This example uses the nodeValue property to replace data in a text node.


Replace an Element Node

The replaceChild() method is used to replace a node.

The following code fragment replaces the first <book> element:

Example

xmlDoc=loadXMLDoc("books.xml");

x=xmlDoc.documentElement;

//create a book element, title element and a text node
newNode=xmlDoc.createElement("book");
newTitle=xmlDoc.createElement("title");
newText=xmlDoc.createTextNode("A Notebook");

//add the text node to the title node,
newTitle.appendChild(newText);
//add the title node to the book node
newNode.appendChild(newTitle);

y=xmlDoc.getElementsByTagName("book")[0]
//replace the first book node with the new node
x.replaceChild(newNode,y);

Try it yourself »

Example explained:

  1. Load "books.xml" into xmlDoc using loadXMLDoc()
  2. Create a new element node <book>
  3. Create a new element node <title>
  4. Create a new text node with the text "A Notebook"
  5. Append the new text node to the new element node <title>
  6. Append the new element node <title> to the new element node <book>
  7. Replace the first <book> element node with the new <book> element node

Replace Data In a Text Node

The replaceData() method is used to replace data in a text node.

The replaceData() method has three parameters:

  • offset - Where to begin replacing characters. Offset value starts at zero
  • length - How many characters to replace
  • string - The string to insert

Example

xmlDoc=loadXMLDoc("books.xml");

x=xmlDoc.getElementsByTagName("title")[0].childNodes[0];

x.replaceData(0,8,"Easy");

Try it yourself »

Example explained:

  1. Load "books.xml" into xmlDoc using loadXMLDoc()
  2. Get the text node of the first <title> element node
  3. Use the replaceDat method to replace the eight first characters from the text node with "Easy"

Use the nodeValue Property Instead

It is easier to replace the data in a text node using the nodeValue property.

The following code fragment will replace the text node value in the first <title> element with "Easy Italian":

Example

xmlDoc=loadXMLDoc("books.xml");

x=xmlDoc.getElementsByTagName("title")[0].childNodes[0];

x.nodeValue="Easy Italian";

Try it yourself »

Example explained:

  1. Load "books.xml" into xmlDoc using loadXMLDoc()
  2. Get the text node of the first <title> element node
  3. Use the nodeValue property to change the text of the text node

You can read more about changing node values in the Change Node chapter.


« Previous Next Chapter »


DreamTemplate


WEB HOSTING
Best Web Hosting
PHP MySQL Hosting
Top 10 Web Hosting
UK Reseller Hosting
Web Hosting
FREE Web Hosting
Top Web Hosting
Windows Hosting
WEB BUILDING
Download XML editor
FREE Flash Website
FREE Web Templates
Website Monetization
FLIGHT TICKETS
Find the cheapest flight
to any destination now!
EDUCATION
US Web Design Schools
HTML Certification
JavaScript Certification
XML Certification
PHP Certification
ASP Certification
STATISTICS
Browser Statistics
Browser OS
Browser Display
W3Schools.com HOME | TOP | PRINT | FORUM | ABOUT
W3Schools is for training only. We do not warrant the correctness of its content. The risk from using it lies entirely with the user.
While using this site, you agree to have read and accepted our terms of use and privacy policy.
Copyright 1999-2009 by Refsnes Data. All Rights Reserved.