Udostępnij za pośrednictwem


XPathNavigator.DeleteSelf Metoda

Definicja

Usuwa bieżący węzeł i jego węzły podrzędne.

public:
 virtual void DeleteSelf();
public virtual void DeleteSelf ();
abstract member DeleteSelf : unit -> unit
override this.DeleteSelf : unit -> unit
Public Overridable Sub DeleteSelf ()

Wyjątki

Element XPathNavigator znajduje się w węźle, którego nie można usunąć, takiego jak węzeł główny lub węzeł przestrzeni nazw.

Element XPathNavigator nie obsługuje edycji.

Przykłady

W poniższym przykładzie price element pierwszego book elementu contosoBooks.xml pliku jest usuwany przy użyciu DeleteSelf metody . Pozycja XPathNavigator obiektu po usunięciu price elementu znajduje się w elemecie nadrzędnym book .

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->DeleteSelf();

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.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)

W przykładzie plik jest contosoBooks.xml pobierany jako dane wejściowe.

<?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>  

Uwagi

  • Element XPathNavigator jest umieszczony w węźle nadrzędnym usuniętego węzła po pomyślnym usunięciu.

  • Jeśli usunięty węzeł jest węzłem tekstowym, który jest zawartością prostego typu elementu, element traci informacje o typie. Oznacza to, że w przypadku ustawienia elementu XmlTypewłaściwości , ValueType i TypedValue mają odpowiednio wartości nulli StringEmpty .

  • Usunięte węzły są nadal dostępne dla XPathNavigator obiektów umieszczonych nad nimi przed usunięciem. Jednak metody, które próbują odejść od usuniętego drzewa podrzędnego, kończą się niepowodzeniem. Na przykład metody i MoveToPrevious zawsze kończą się niepowodzeniem, MoveToParent gdy XPathNavigator obiekt znajduje się nad najbardziej usuniętym węzłem. Dzieje się tak, ponieważ usunięty węzeł nie jest już połączony z dokumentem XML. MoveToNext Podobnie metoda zawsze kończy się niepowodzeniem, jeśli XPathNavigator element znajduje się na najbardziej usuniętym dolnym węźle.

Dotyczy