다음을 통해 공유


XPathNavigator.DeleteSelf 메서드

정의

현재 노드와 해당 자식 노드를 삭제합니다.

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

예외

XPathNavigator가 삭제할 수 없는 노드(예: 루트 노드 또는 네임스페이스 노드)에 있습니다.

XPathNavigator에서는 편집을 지원하지 않습니다.

예제

다음 예제에서는 메서드를 price 사용하여 파일의 contosoBooks.xml 첫 번째 book 요소 요소를 삭제합니다DeleteSelf. XPathNavigator 요소를 삭제한 후 price 개체는 부모 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)

이 예제에서는 contosoBooks.xml 파일을 입력으로 사용합니다.

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

설명

  • XPathNavigator 성공적으로 삭제될 때 삭제된 노드의 부모 노드에 배치됩니다.

  • 삭제된 노드가 단순 형식 요소의 내용인 텍스트 노드인 경우 요소는 해당 형식 정보를 잃게 됩니다. 즉, 요소XmlType에 배치할 때 , ValueTypeTypedValue 속성에는 각각 및 값 nullStringEmpty 이 있습니다.

  • 삭제된 노드는 삭제하기 전에 해당 노드 위에 배치된 개체에 계속 액세스할 수 XPathNavigator 있습니다. 그러나 삭제된 하위 트리에서 벗어나려는 메서드는 실패합니다. 예를 들어 및 MoveToPrevious 메서드는 MoveToParent 가 가장 많이 삭제된 최상위 노드 위에 위치할 때 XPathNavigator 항상 실패합니다. 삭제된 노드가 더 이상 XML 문서에 연결되지 않은 때문입니다. 마찬가지로 메서드는 MoveToNext 가 가장 많이 삭제된 최하위 노드에 있는 경우 XPathNavigator 항상 실패합니다.

적용 대상