Export (0) Print
Expand All
1 out of 4 rated this helpful - Rate this topic

IHasXmlNode Interface

Enables a class to return an XmlNode from the current context or position.

Namespace:  System.Xml
Assembly:  System.Xml (in System.Xml.dll)
public interface IHasXmlNode

The IHasXmlNode interface provides an interface that enables a class to return an XmlNode from the current context or position. It is implemented by XPathNavigator objects that operate over classes that have XmlNode nodes. For example, if the XPathNavigator object is created by an XmlDocument, you can use the GetNode method to return the XmlNode representing the current position of the navigator.

The following example uses the GetNode method to retrieve and modify the selected node.

using System;
using System.IO;
using System.Xml;
using System.Xml.XPath;

public class Sample
{
  public static void Main()
  {
     XmlDocument doc = new XmlDocument();
     doc.Load("books.xml");

     // Create an XPathNavigator and select all books by Plato.
     XPathNavigator nav = doc.CreateNavigator();
     XPathNodeIterator ni = nav.Select("descendant::book[author/name='Plato']");
     ni.MoveNext();

     // Get the first matching node and change the book price.
     XmlNode book = ((IHasXmlNode)ni.Current).GetNode();
     book.LastChild.InnerText = "12.95";
     Console.WriteLine(book.OuterXml);

  }
}
#using <mscorlib.dll>
#using <System.Xml.dll>
using namespace System;
using namespace System::IO;
using namespace System::Xml;
using namespace System::Xml::XPath;

int main() {
   XmlDocument* doc = new XmlDocument();
   doc -> Load(S"books.xml");

   // Create an XPathNavigator and select all books by Plato.
   XPathNavigator * nav = doc -> CreateNavigator();
   XPathNodeIterator * ni = nav -> Select(S"descendant::book[author/name='Plato']");
   ni -> MoveNext();

   // Get the first matching node and change the book price.
   XmlNode * book = dynamic_cast<IHasXmlNode*>(ni -> Current)->GetNode();
   book -> LastChild -> InnerText = S"12.95";
   Console::WriteLine(book -> OuterXml); 
}

The example uses the file books.xml as input.

<bookstore>
  <book genre="autobiography" publicationdate="1981" ISBN="1-861003-11-0">
    <title>The Autobiography of Benjamin Franklin</title>
    <author>
      <first-name>Benjamin</first-name>
      <last-name>Franklin</last-name>
    </author>
    <price>8.99</price>
  </book>
  <book genre="novel" publicationdate="1967" ISBN="0-201-63361-2">
    <title>The Confidence Man</title>
    <author>
      <first-name>Herman</first-name>
      <last-name>Melville</last-name>
    </author>
    <price>11.99</price>
  </book>
  <book genre="philosophy" publicationdate="1991" ISBN="1-861001-57-6">
    <title>The Gorgias</title>
    <author>
      <name>Plato</name>
    </author>
    <price>9.99</price>
  </book>
</bookstore>

Windows 7, Windows Vista, Windows XP SP2, Windows XP Media Center Edition, Windows XP Professional x64 Edition, Windows XP Starter Edition, Windows Server 2008 R2, Windows Server 2008, Windows Server 2003, Windows Server 2000 SP4, Windows Millennium Edition, Windows 98, Windows CE, Windows Mobile for Smartphone, Windows Mobile for Pocket PC, Xbox 360, Zune

The .NET Framework and .NET Compact Framework do not support all versions of every platform. For a list of the supported versions, see .NET Framework System Requirements.

.NET Framework

Supported in: 3.5, 3.0, 2.0, 1.1, 1.0

.NET Compact Framework

Supported in: 3.5, 2.0

XNA Framework

Supported in: 3.0, 2.0, 1.0

Community Additions

ADD
Show:
© 2014 Microsoft. All rights reserved.