XPathNavigator.DeleteSelf メソッド
定義
重要
一部の情報は、リリース前に大きく変更される可能性があるプレリリースされた製品に関するものです。 Microsoft は、ここに記載されている情報について、明示または黙示を問わず、一切保証しません。
現在のノードとその子ノードを削除します。
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
使用して、ファイルの最初 book
の contosoBooks.xml
要素の要素が 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は、正常に削除されると、削除されたノードの親ノードに配置されます。
削除されたノードが、単純な型指定された要素の内容であるテキスト ノードである場合、要素は型情報を失います。 つまり、要素に配置されると、 XmlTypeValueType プロパティと TypedValue プロパティの値
null
はそれぞれ になります StringEmpty。削除されたノードは、削除前にそれらの上に XPathNavigator 配置されたオブジェクトから引き続きアクセスできます。 ただし、削除されたサブツリーから移動しようとするメソッドは失敗します。 たとえば、 MoveToParent メソッドと MoveToPrevious メソッドは、 が最も削除された最上位ノード上に配置されると XPathNavigator 、常に失敗します。 これは、削除されたノードが XML ドキュメントに接続されなくなったためです。 同様に、 が MoveToNext 最も削除されたノードに配置されている場合 XPathNavigator 、メソッドは常に失敗します。
適用対象
.NET