XPathNavigator.DeleteSelf Método
Definição
Importante
Algumas informações dizem respeito a um produto pré-lançado que pode ser substancialmente modificado antes de ser lançado. A Microsoft não faz garantias, de forma expressa ou implícita, em relação à informação aqui apresentada.
Elimina o nó atual e os seus nós filhos.
public:
virtual void DeleteSelf();
public virtual void DeleteSelf();
abstract member DeleteSelf : unit -> unit
override this.DeleteSelf : unit -> unit
Public Overridable Sub DeleteSelf ()
Exceções
O XPathNavigator está posicionado num nó que não pode ser eliminado, como o nó raiz ou um nó de namespace.
Não XPathNavigator suporta edição.
Exemplos
No exemplo seguinte, o price elemento do primeiro book elemento do contosoBooks.xml ficheiro é eliminado usando o DeleteSelf método. A posição do XPathNavigator objeto depois que o price elemento é excluído está no elemento pai book .
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.DeleteSelf();
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.DeleteSelf()
Console.WriteLine("Position after delete: {0}", navigator.Name)
Console.WriteLine(navigator.OuterXml)
O exemplo usa o contosoBooks.xml arquivo como uma 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>
Observações
O XPathNavigator é posicionado no nó pai do nó eliminado após a eliminação bem-sucedida.
Se o nó eliminado for um nó de texto que é o conteúdo de um elemento tipo simples, o elemento perde a sua informação de tipo. Isto significa que, quando posicionados sobre o elemento, os XmlType, ValueType e TypedValue as propriedades têm os valores
null, String e Empty respetivamente.Os nós eliminados ainda estão acessíveis a XPathNavigator objetos posicionados sobre eles antes da eliminação. No entanto, métodos que tentam afastar-se da subárvore eliminada falham. Por exemplo, os MoveToParent métodos e MoveToPrevious falham sempre quando o XPathNavigator está posicionado sobre o nó mais eliminado. Isto deve-se ao facto de o nó eliminado já não estar ligado ao documento XML. De forma semelhante, o MoveToNext método falha sempre se o XPathNavigator estiver posicionado no nó eliminado mais em baixo.