Extensions.Remove Método
Definição
Importante
Algumas informações se referem a produtos de pré-lançamento que podem ser substancialmente modificados antes do lançamento. A Microsoft não oferece garantias, expressas ou implícitas, das informações aqui fornecidas.
Sobrecargas
Remove(IEnumerable<XAttribute>) |
Remove cada atributo na coleção de origem do respectivo elemento pai. |
Remove<T>(IEnumerable<T>) |
Remove todos os nós na coleção de origem do respectivo nó pai. |
Remove(IEnumerable<XAttribute>)
Remove cada atributo na coleção de origem do respectivo elemento pai.
public:
[System::Runtime::CompilerServices::Extension]
static void Remove(System::Collections::Generic::IEnumerable<System::Xml::Linq::XAttribute ^> ^ source);
public static void Remove (this System.Collections.Generic.IEnumerable<System.Xml.Linq.XAttribute> source);
public static void Remove (this System.Collections.Generic.IEnumerable<System.Xml.Linq.XAttribute?> source);
static member Remove : seq<System.Xml.Linq.XAttribute> -> unit
<Extension()>
Public Sub Remove (source As IEnumerable(Of XAttribute))
Parâmetros
- source
- IEnumerable<XAttribute>
Um IEnumerable<T> do XAttribute que contém a coleção de origem.
Exemplos
O exemplo a seguir recupera uma coleção de atributos e chama esse método para removê-los de seus elementos pai.
XElement root = new XElement("Root",
new XAttribute("Att1", 1),
new XAttribute("Att2", 2),
new XAttribute("Att3", 3),
new XAttribute("Att4", 4),
new XAttribute("Att5", 5)
);
IEnumerable<XAttribute> atList =
from at in root.Attributes()
where (int)at >= 3
select at;
atList.Remove();
Console.WriteLine(root);
Dim root As XElement = <Root Att1="1" Att2="2" Att3="3" Att4="4" Att5="5"/>
Dim atList = From at In root.Attributes _
Where at.Value >= 3 _
Select at
atList.Remove()
Console.WriteLine(root)
Esse exemplo gera a saída a seguir:
<Root Att1="1" Att2="2" />
Comentários
Esse método usa semântica de instantâneo – ou seja, copia os atributos na coleção de origem para um System.Collections.Generic.List<T> antes de desconectá-los de seus pais. Isso é necessário para evitar problemas com código imperativo/declarativo misto. Para obter mais informações, consulte Código Declarativo Misto/Bugs de Código Imperativo (LINQ to XML).
Confira também
Aplica-se a
Remove<T>(IEnumerable<T>)
Remove todos os nós na coleção de origem do respectivo nó pai.
public:
generic <typename T>
where T : System::Xml::Linq::XNode[System::Runtime::CompilerServices::Extension]
static void Remove(System::Collections::Generic::IEnumerable<T> ^ source);
public static void Remove<T> (this System.Collections.Generic.IEnumerable<T> source) where T : System.Xml.Linq.XNode;
public static void Remove<T> (this System.Collections.Generic.IEnumerable<T?> source) where T : System.Xml.Linq.XNode;
static member Remove : seq<'T (requires 'T :> System.Xml.Linq.XNode)> -> unit (requires 'T :> System.Xml.Linq.XNode)
<Extension()>
Public Sub Remove(Of T As XNode) (source As IEnumerable(Of T))
Parâmetros de tipo
- T
O tipo dos objetos em source
, restritos para XNode.
Parâmetros
- source
- IEnumerable<T>
Um IEnumerable<T> do XNode que contém a coleção de origem.
Exemplos
O exemplo a seguir recupera uma coleção de elementos. Em seguida, ele chama esse método para remover os elementos de seu elemento pai.
XElement root = new XElement("Root",
new XElement("Data", 1),
new XElement("Data", 2),
new XElement("Data", 3),
new XElement("Data", 4),
new XElement("Data", 5)
);
IEnumerable<XElement> elList =
from el in root.Elements()
where (int)el >= 3
select el;
elList.Remove();
Console.WriteLine(root);
Dim root As XElement = _
<Root>
<Data>1</Data>
<Data>2</Data>
<Data>3</Data>
<Data>4</Data>
<Data>5</Data>
</Root>
Dim elList = From el In root.Elements _
Where el.Value >= 3 _
Select el
elList.Remove()
Console.WriteLine(root)
Esse exemplo gera a saída a seguir:
<Root>
<Data>1</Data>
<Data>2</Data>
</Root>
Comentários
Esse método usa semântica de instantâneo – ou seja, copia os atributos na coleção de origem para um List<T>
antes de desconectá-los de seus pais. Isso é necessário para evitar problemas com código imperativo/declarativo misto. Para obter mais informações, consulte Código Declarativo Misto/Bugs de Código Imperativo (LINQ to XML).