Export (0) Print
Expand All
This topic has not yet been rated - Rate this topic

XContainer.ReplaceNodes Method

Replaces the children nodes of this document or element with the specified content.

This member is overloaded. For complete information about this member, including syntax, usage, and examples, click a name in the overload list.

  Name Description
Public method ReplaceNodes(Object) Replaces the children nodes of this document or element with the specified content.
Public method ReplaceNodes(Object[]) Replaces the children nodes of this document or element with the specified content.
Top

For details about the valid content that can be passed to this function, see Valid Content of XElement and XDocument Objects.

This method will raise the Changed and the Changing events.

This method has snapshot semantics. It first creates a copy of the new content. It then removes all children nodes of this node. Finally, it adds the new content as children nodes. This means that you can replace children nodes using a query on the children nodes themselves.

The following example creates two XML trees, and then uses this method to replace the contents of one of them with the results of a query.

XElement root = new XElement("Root",
    new XElement("Child", 1),
    new XElement("Child", 2),
    new XElement("Child", 3),
    new XElement("Child", 4),
    new XElement("Child", 5)
);
root.ReplaceNodes(
    from el in root.Elements()
    where (int)el >= 3
    select el
);
Console.WriteLine(root);

This example produces the following output:

<Root>
  <Child>3</Child>
  <Child>4</Child>
  <Child>5</Child>
</Root>
Did you find this helpful?
(1500 characters remaining)
Thank you for your feedback
Show:
© 2014 Microsoft. All rights reserved.