Literais XML no Visual Basic (LINQ to XML)
Este artigo fornece informações sobre como criar árvores XML no Visual Basic usando literais XML e expressões incorporadas.
Exemplo: Usar literais XML para criar uma árvore XML
O exemplo a seguir mostra como criar um XElement, neste caso contacts
, com literais XML:
Dim contacts As XElement = _
<Contacts>
<Contact>
<Name>Patrick Hines</Name>
<Phone>206-555-0144</Phone>
<Address>
<Street1>123 Main St</Street1>
<City>Mercer Island</City>
<State>WA</State>
<Postal>68042</Postal>
</Address>
</Contact>
</Contacts>
Exemplo: Use literais XML para criar um XElement com conteúdo simples
Você pode criar um que contenha conteúdo XElement simples, da seguinte maneira:
Dim n as XElement = <Customer>Adventure Works</Customer>
Console.WriteLine(n)
Este exemplo produz a seguinte saída:
<Customer>Adventure Works</Customer>
Exemplo: usar um literal XML para criar um elemento vazio
Você pode criar um vazio XElement, da seguinte maneira:
Dim n As XElement = <Customer/>
Console.WriteLine(n)
Este exemplo produz a seguinte saída:
<Customer />
Usar expressões incorporadas para criar conteúdo
Uma característica importante dos literais XML é que eles permitem expressões incorporadas. As expressões incorporadas permitem avaliar uma expressão e inserir os resultados da expressão na árvore XML. Se a expressão for avaliada como um tipo de XElement, um elemento será inserido na árvore. Se a expressão for avaliada como um tipo de XAttribute, um atributo será inserido na árvore. Você pode inserir elementos e atributos na árvore somente onde eles são válidos.
É importante notar que apenas uma única expressão pode entrar em uma expressão incorporada. Não é possível incorporar várias instruções. Se uma expressão se estender além de uma única linha, você deverá usar o caractere de continuação de linha.
Se você usar uma expressão incorporada para adicionar nós existentes (incluindo elementos) e atributos a uma nova árvore XML e se os nós existentes já tiverem parentes, os nós serão clonados. Os nós recém-clonados são anexados à nova árvore XML. Se os nós existentes não forem parentes, os nós serão simplesmente anexados à nova árvore XML. O último exemplo neste artigo demonstra isso.
Exemplo: usar uma expressão incorporada para inserir um elemento
O exemplo a seguir usa uma expressão incorporada para inserir um elemento na árvore:
xmlTree1 As XElement = _
<Root>
<Child>Contents</Child>
</Root>
Dim xmlTree2 As XElement = _
<Root>
<%= xmlTree1.<Child> %>
</Root>
Console.WriteLine(xmlTree2)
Este exemplo produz a seguinte saída:
<Root>
<Child>Contents</Child>
</Root>
Exemplo: usar uma expressão incorporada para conteúdo
Você pode usar uma expressão incorporada para fornecer o conteúdo de um elemento:
Dim str As String
str = "Some content"
Dim root As XElement = <Root><%= str %></Root>
Console.WriteLine(root)
Este exemplo produz a seguinte saída:
<Root>Some content</Root>
Exemplo: usar uma consulta LINQ em uma expressão incorporada
Você pode usar os resultados de uma consulta LINQ para fornecer o conteúdo de um elemento:
Dim arr As Integer() = {1, 2, 3}
Dim n As XElement = _
<Root>
<%= From i In arr Select <Child><%= i %></Child> %>
</Root>
Console.WriteLine(n)
Este exemplo produz a seguinte saída:
<Root>
<Child>1</Child>
<Child>2</Child>
<Child>3</Child>
</Root>
Exemplo: usar uma expressão incorporada para fornecer nomes de nó
Você também pode usar uma expressão incorporada para calcular nomes de atributos, valores de atributos, nomes de elementos e valores de elementos:
Dim eleName As String = "ele"
Dim attName As String = "att"
Dim attValue As String = "aValue"
Dim eleValue As String = "eValue"
Dim n As XElement = _
<Root <%= attName %>=<%= attValue %>>
<<%= eleName %>>
<%= eleValue %>
</>
</Root>
Console.WriteLine(n)
Este exemplo produz a seguinte saída:
<Root att="aValue">
<ele>eValue</ele>
</Root>
Exemplo: usar uma expressão incorporada para clonar e anexar nós
Como mencionado anteriormente, se você usar uma expressão incorporada para adicionar nós existentes (incluindo elementos) e atributos a uma nova árvore XML, e se os nós que estão sendo adicionados já tiverem parentes, os nós serão clonados e os clones serão anexados à nova árvore XML. Se os nós existentes não forem parentes, eles serão simplesmente anexados à nova árvore XML.
O código a seguir demonstra o comportamento quando você adiciona um elemento pai a uma árvore e quando você adiciona um elemento sem pai a uma árvore.
' Create a tree with a child element.
Dim xmlTree1 As XElement = _
<Root>
<Child1>1</Child1>
</Root>
' Create an element that's not parented.
Dim child2 As XElement = <Child2>2</Child2>
' Create a tree and add Child1 and Child2 to it.
Dim xmlTree2 As XElement = _
<Root>
<%= xmlTree1.<Child1>(0) %>
<%= child2 %>
</Root>
' Compare Child1 identity.
Console.WriteLine("Child1 was {0}", _
IIf(xmlTree1.Element("Child1") Is xmlTree2.Element("Child1"), _
"attached", "cloned"))
' Compare Child2 identity.
Console.WriteLine("Child2 was {0}", _
IIf(child2 Is xmlTree2.Element("Child2"), _
"attached", "cloned"))
Este exemplo produz a seguinte saída:
Child1 was cloned
Child2 was attached