Extensions.Remove<T> Method (IEnumerable<T>)
Microsoft Silverlight will reach end of support after October 2021. Learn more.
Removes every node in the source collection from its parent node.
Namespace:  System.Xml.Linq
Assembly:  System.Xml.Linq (in System.Xml.Linq.dll)
Syntax
'Declaration
<ExtensionAttribute> _
Public Shared Sub Remove(Of T As XNode) ( _
    source As IEnumerable(Of T) _
)
public static void Remove<T>(
    this IEnumerable<T> source
)
where T : XNode
Type Parameters
- T
 The type of the objects in source, constrained to XNode.
Parameters
- source
 Type: System.Collections.Generic.IEnumerable<T>
 An IEnumerable<T> of XNode that contains the source collection.
Usage Note
In Visual Basic and C#, you can call this method as an instance method on any object of type IEnumerable<T>. When you use instance method syntax to call this method, omit the first parameter.
Exceptions
| Exception | Condition | 
|---|---|
| ArgumentNullException | source is nulla null reference (Nothing in Visual Basic). | 
Remarks
This method uses snapshot semantics—that is, it copies the nodes in the source collection to a List<T> before disconnecting them from their parents. This is required to avoid issues with mixed imperative/declarative code. For more information, see Mixed Declarative Code/Imperative Code Bugs in the .NET Framework documentation.
Version Information
Silverlight
Supported in: 5, 4, 3
Silverlight for Windows Phone
Supported in: Windows Phone OS 7.1, Windows Phone OS 7.0
XNA Framework
Supported in: Xbox 360, Windows Phone OS 7.0
Platforms
For a list of the operating systems and browsers that are supported by Silverlight, see Supported Operating Systems and Browsers.
See Also