Partilhar via


XPathNavigator.ReplaceSelf Método

Definição

Substitui o nó atual com o conteúdo especificado.

Sobrecargas

ReplaceSelf(XmlReader)

Substitui o nó atual com o conteúdo do objeto XmlReader especificado.

ReplaceSelf(XPathNavigator)

Substitui o nó atual com o conteúdo do objeto XPathNavigator especificado.

ReplaceSelf(String)

Substitui o nó atual com o conteúdo da cadeia de caracteres especificada.

ReplaceSelf(XmlReader)

Origem:
XPathNavigator.cs
Origem:
XPathNavigator.cs
Origem:
XPathNavigator.cs

Substitui o nó atual com o conteúdo do objeto XmlReader especificado.

public:
 virtual void ReplaceSelf(System::Xml::XmlReader ^ newNode);
public virtual void ReplaceSelf (System.Xml.XmlReader newNode);
abstract member ReplaceSelf : System.Xml.XmlReader -> unit
override this.ReplaceSelf : System.Xml.XmlReader -> unit
Public Overridable Sub ReplaceSelf (newNode As XmlReader)

Parâmetros

newNode
XmlReader

Um objeto XmlReader posicionado nos dados XML para o novo nó.

Exceções

O objeto XmlReader está em um estado de erro ou fechado.

O parâmetro do objeto XmlReader é null.

O XPathNavigator não está posicionado em um elemento, um texto, uma instrução de processamento ou em um nó de comentário.

O XPathNavigator não dá suporte à edição.

O conteúdo XML do parâmetro de objeto XmlReader não está bem formado.

Exemplos

No exemplo a seguir, o price elemento no contosoBooks.xml arquivo é substituído por um novo pages elemento .

XmlDocument^ document = gcnew XmlDocument();
document->Load("contosoBooks.xml");
XPathNavigator^ navigator = document->CreateNavigator();

navigator->MoveToChild("bookstore", "http://www.contoso.com/books");
navigator->MoveToChild("book", "http://www.contoso.com/books");
navigator->MoveToChild("price", "http://www.contoso.com/books");

XmlReader^ pages = XmlReader::Create(gcnew StringReader("<pages xmlns=\"http://www.contoso.com/books\">100</pages>"));

navigator->ReplaceSelf(pages);

Console::WriteLine("Position after delete: {0}", navigator->Name);
Console::WriteLine(navigator->OuterXml);
XmlDocument document = new XmlDocument();
document.Load("contosoBooks.xml");
XPathNavigator navigator = document.CreateNavigator();

navigator.MoveToChild("bookstore", "http://www.contoso.com/books");
navigator.MoveToChild("book", "http://www.contoso.com/books");
navigator.MoveToChild("price", "http://www.contoso.com/books");

XmlReader pages = XmlReader.Create(new StringReader("<pages xmlns=\"http://www.contoso.com/books\">100</pages>"));

navigator.ReplaceSelf(pages);

Console.WriteLine("Position after delete: {0}", navigator.Name);
Console.WriteLine(navigator.OuterXml);
Dim document As XmlDocument = New XmlDocument()
document.Load("contosoBooks.xml")
Dim navigator As XPathNavigator = document.CreateNavigator()

navigator.MoveToChild("bookstore", "http://www.contoso.com/books")
navigator.MoveToChild("book", "http://www.contoso.com/books")
navigator.MoveToChild("price", "http://www.contoso.com/books")

Dim pages As XmlReader = XmlReader.Create(New StringReader("<pages xmlns='http://www.contoso.com/books'>100</pages>"))

navigator.ReplaceSelf(pages)

Console.WriteLine("Position after delete: {0}", navigator.Name)
Console.WriteLine(navigator.OuterXml)

O exemplo usa o arquivo contosoBooks.xml como entrada.

<?xml version="1.0" encoding="utf-8" ?>  
<bookstore xmlns="http://www.contoso.com/books">  
    <book genre="autobiography" publicationdate="1981-03-22" 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-11-17" 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-02-15" ISBN="1-861001-57-6">  
        <title>The Gorgias</title>  
        <author>  
            <name>Plato</name>  
        </author>  
        <price>9.99</price>  
    </book>  
</bookstore>  

Comentários

O XPathNavigator é posicionado no novo nó após a conclusão do ReplaceSelf método e retorna true. O XPathNavigator não é posicionado no novo nó após a ReplaceSelf conclusão do método quando a entrada XML está Empty , nesse caso, o XPathNavigator é posicionado no próximo nó irmão ou no nó pai se não houver nenhum nó irmão próximo para o nó substituído e o ReplaceSelf retornar false.

  • O ReplaceSelf método é válido somente quando o XPathNavigator é posicionado em um elemento, texto, instrução de processamento ou nó de comentário.

  • Se a cadeia de caracteres de dados XML não estiver bem formada do que uma exceção for gerada e o resultado desse método for equivalente a chamar DeleteSelf no nó atual.

  • Se a cadeia de caracteres XML contiver vários nós, todos os nós serão adicionados e o XPathNavigator será posicionado no primeiro nó da série de nós.

  • O ReplaceSelf método não é equivalente ao DeleteSelf método .

Aplica-se a

ReplaceSelf(XPathNavigator)

Origem:
XPathNavigator.cs
Origem:
XPathNavigator.cs
Origem:
XPathNavigator.cs

Substitui o nó atual com o conteúdo do objeto XPathNavigator especificado.

public:
 virtual void ReplaceSelf(System::Xml::XPath::XPathNavigator ^ newNode);
public virtual void ReplaceSelf (System.Xml.XPath.XPathNavigator newNode);
abstract member ReplaceSelf : System.Xml.XPath.XPathNavigator -> unit
override this.ReplaceSelf : System.Xml.XPath.XPathNavigator -> unit
Public Overridable Sub ReplaceSelf (newNode As XPathNavigator)

Parâmetros

newNode
XPathNavigator

Um objeto XPathNavigator posicionado no novo nó.

Exceções

O parâmetro do objeto XPathNavigator é null.

O XPathNavigator não está posicionado em um elemento, um texto, uma instrução de processamento ou em um nó de comentário.

O XPathNavigator não dá suporte à edição.

O conteúdo XML do parâmetro de objeto XPathNavigator não está bem formado.

Exemplos

No exemplo a seguir, o price elemento no contosoBooks.xml arquivo é substituído por um novo pages elemento .

XmlDocument^ document = gcnew XmlDocument();
document->Load("contosoBooks.xml");
XPathNavigator^ navigator = document->CreateNavigator();

navigator->MoveToChild("bookstore", "http://www.contoso.com/books");
navigator->MoveToChild("book", "http://www.contoso.com/books");
navigator->MoveToChild("price", "http://www.contoso.com/books");

XmlDocument^ childNodes = gcnew XmlDocument();
childNodes->Load(gcnew StringReader("<pages xmlns=\"http://www.contoso.com/books\">100</pages>"));
XPathNavigator^ childNodesNavigator = childNodes->CreateNavigator();

navigator->ReplaceSelf(childNodesNavigator);

Console::WriteLine("Position after delete: {0}", navigator->Name);
Console::WriteLine(navigator->OuterXml);
XmlDocument document = new XmlDocument();
document.Load("contosoBooks.xml");
XPathNavigator navigator = document.CreateNavigator();

navigator.MoveToChild("bookstore", "http://www.contoso.com/books");
navigator.MoveToChild("book", "http://www.contoso.com/books");
navigator.MoveToChild("price", "http://www.contoso.com/books");

XmlDocument childNodes = new XmlDocument();
childNodes.Load(new StringReader("<pages xmlns=\"http://www.contoso.com/books\">100</pages>"));
XPathNavigator childNodesNavigator = childNodes.CreateNavigator();

navigator.ReplaceSelf(childNodesNavigator);

Console.WriteLine("Position after delete: {0}", navigator.Name);
Console.WriteLine(navigator.OuterXml);
Dim document As XmlDocument = New XmlDocument()
document.Load("contosoBooks.xml")
Dim navigator As XPathNavigator = document.CreateNavigator()

navigator.MoveToChild("bookstore", "http://www.contoso.com/books")
navigator.MoveToChild("book", "http://www.contoso.com/books")
navigator.MoveToChild("price", "http://www.contoso.com/books")

Dim childNodes As XmlDocument = New XmlDocument()
childNodes.Load(New StringReader("<pages xmlns='http://www.contoso.com/books'>100</pages>"))
Dim childNodesNavigator As XPathNavigator = childNodes.CreateNavigator()

navigator.ReplaceSelf(childNodesNavigator)

Console.WriteLine("Position after delete: {0}", navigator.Name)
Console.WriteLine(navigator.OuterXml)

O exemplo usa o arquivo contosoBooks.xml como entrada.

<?xml version="1.0" encoding="utf-8" ?>  
<bookstore xmlns="http://www.contoso.com/books">  
    <book genre="autobiography" publicationdate="1981-03-22" 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-11-17" 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-02-15" ISBN="1-861001-57-6">  
        <title>The Gorgias</title>  
        <author>  
            <name>Plato</name>  
        </author>  
        <price>9.99</price>  
    </book>  
</bookstore>  

Comentários

O XPathNavigator é posicionado no novo nó após a conclusão do ReplaceSelf método e retorna true. O XPathNavigator não é posicionado no novo nó após a ReplaceSelf conclusão do método quando a entrada XML está Empty , nesse caso, o XPathNavigator é posicionado no próximo nó irmão ou no nó pai se não houver nenhum nó irmão próximo para o nó substituído e o ReplaceSelf retornar false.

  • O ReplaceSelf método é válido somente quando o XPathNavigator é posicionado em um elemento, texto, instrução de processamento ou nó de comentário.

  • Se a cadeia de caracteres de dados XML não estiver bem formada do que uma exceção for gerada e o resultado desse método for equivalente a chamar DeleteSelf no nó atual.

  • Se a cadeia de caracteres XML contiver vários nós, todos os nós serão adicionados e o XPathNavigator será posicionado no primeiro nó da série de nós.

  • O ReplaceSelf método não é equivalente ao DeleteSelf método .

Aplica-se a

ReplaceSelf(String)

Origem:
XPathNavigator.cs
Origem:
XPathNavigator.cs
Origem:
XPathNavigator.cs

Substitui o nó atual com o conteúdo da cadeia de caracteres especificada.

public:
 virtual void ReplaceSelf(System::String ^ newNode);
public virtual void ReplaceSelf (string newNode);
abstract member ReplaceSelf : string -> unit
override this.ReplaceSelf : string -> unit
Public Overridable Sub ReplaceSelf (newNode As String)

Parâmetros

newNode
String

A cadeia de dados XML para o novo nó.

Exceções

O parâmetro da cadeia de caracteres XML é null.

O XPathNavigator não está posicionado em um elemento, um texto, uma instrução de processamento ou em um nó de comentário.

O XPathNavigator não dá suporte à edição.

O parâmetro da cadeia de caracteres XML não está bem formado.

Exemplos

No exemplo a seguir, o price elemento no contosoBooks.xml arquivo é substituído por um novo pages elemento .

XmlDocument^ document = gcnew XmlDocument();
document->Load("contosoBooks.xml");
XPathNavigator^ navigator = document->CreateNavigator();

navigator->MoveToChild("bookstore", "http://www.contoso.com/books");
navigator->MoveToChild("book", "http://www.contoso.com/books");
navigator->MoveToChild("price", "http://www.contoso.com/books");

navigator->ReplaceSelf("<pages>100</pages>");

Console::WriteLine("Position after delete: {0}", navigator->Name);
Console::WriteLine(navigator->OuterXml);
XmlDocument document = new XmlDocument();
document.Load("contosoBooks.xml");
XPathNavigator navigator = document.CreateNavigator();

navigator.MoveToChild("bookstore", "http://www.contoso.com/books");
navigator.MoveToChild("book", "http://www.contoso.com/books");
navigator.MoveToChild("price", "http://www.contoso.com/books");

navigator.ReplaceSelf("<pages>100</pages>");

Console.WriteLine("Position after delete: {0}", navigator.Name);
Console.WriteLine(navigator.OuterXml);
Dim document As XmlDocument = New XmlDocument()
document.Load("contosoBooks.xml")
Dim navigator As XPathNavigator = document.CreateNavigator()

navigator.MoveToChild("bookstore", "http://www.contoso.com/books")
navigator.MoveToChild("book", "http://www.contoso.com/books")
navigator.MoveToChild("price", "http://www.contoso.com/books")

navigator.ReplaceSelf("<pages>100</pages>")

Console.WriteLine("Position after delete: {0}", navigator.Name)
Console.WriteLine(navigator.OuterXml)

O exemplo usa o arquivo contosoBooks.xml como entrada.

<?xml version="1.0" encoding="utf-8" ?>  
<bookstore xmlns="http://www.contoso.com/books">  
    <book genre="autobiography" publicationdate="1981-03-22" 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-11-17" 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-02-15" ISBN="1-861001-57-6">  
        <title>The Gorgias</title>  
        <author>  
            <name>Plato</name>  
        </author>  
        <price>9.99</price>  
    </book>  
</bookstore>  

Comentários

O XPathNavigator é posicionado no novo nó após a conclusão do ReplaceSelf método e retorna true. O XPathNavigator não é posicionado no novo nó após a ReplaceSelf conclusão do método quando a entrada XML está Empty , nesse caso, o XPathNavigator é posicionado no próximo nó irmão ou no nó pai se não houver nenhum nó irmão próximo para o nó substituído e o ReplaceSelf retornar false.

  • O ReplaceSelf método é válido somente quando o XPathNavigator é posicionado em um elemento, texto, instrução de processamento ou nó de comentário.

  • Se a cadeia de caracteres de dados XML não estiver bem formada do que uma exceção for gerada e o resultado desse método for equivalente a chamar DeleteSelf no nó atual.

  • Se a cadeia de caracteres XML contiver vários nós, todos os nós serão adicionados e o XPathNavigator será posicionado no primeiro nó da série de nós.

  • O ReplaceSelf método não é equivalente ao DeleteSelf método .

Aplica-se a