Načtení uzlů bez stanoveného pořadí podle názvu nebo indexu
XmlNamedNodeMap je popsán ve specifikaci W3C (World Wide Web Consortium) jako NamedNodeMap a je vyžadován pro zpracování neuspořádané sady uzlů s možností odkazovat na uzly podle jejich názvu nebo indexu. Jediný způsob, jak máte přístup k XmlNamedNodeMap je v případě , že XmlNamedNodeMap je vrácen prostřednictvím metody nebo vlastnosti. Existují tři metody nebo vlastnosti, které vracejí XmlNamedNodeMap:
XmlElement.Attributes
XmlDocumentType.Entities
XmlDocumentType.Notations
Například XmlDocumentType.Entities vlastnost získá kolekci xmlEntity uzlů deklarovaných v deklaraci typu dokumentu. Tato kolekce je vrácena jako XmlNamedNodeMap a můžete iterovat kolekci pomocí vlastnosti Count a zobrazit informace o entitě. Příklad iterace prostřednictvím XmlNamedNodeMap naleznete v tématu Entities.
XmlAttributeCollection je odvozen z XmlNamedNodeMap a jsou modifikovatelné pouze atributy, zatímco notace a entity jsou jen pro čtení. Pomocí XmlNamedNodeMap pro atributy můžete získat uzly pro tyto atributy na základě jejich názvů XML. To poskytuje jednoduchou metodu pro manipulaci s kolekcí atributů na uzlu elementu. To lze kontrastovat přímo s XmlNodeList, který také implementuje IEnumerable rozhraní, ale s přístupovým objektem indexu místo řetězce. Metody RemoveNamedItem a SetNamedItem se používají pouze pro XmlAttributeCollection. Přidání nebo odebrání z kolekce atributů, ať už pomocí AttributeCollection nebo XmlNamedNodeMap implementace, modifikuje kolekci atributů v elementu. Následující příklad kódu ukazuje, jak přesunout atribut a vytvořit nový atribut.
Imports System
Imports System.Xml
Class test
Public Shared Sub Main()
Dim doc As New XmlDocument()
doc.LoadXml("<root> <child1 attr1='val1' attr2='val2'> text1 </child1> <child2 attr3='val3'> text2 </child2> </root> ")
' Get the attributes of node "child2 "
Dim ac As XmlAttributeCollection = doc.DocumentElement.ChildNodes(1).Attributes
' Print out the number of attributes and their names.
Console.WriteLine(("Number of Attributes: " + ac.Count))
Dim i As Integer
For i = 0 To ac.Count - 1
Console.WriteLine((i + 1 + ". Attribute Name: '" + ac(i).Name + "' Attribute Value: '" + ac(i).Value + "'"))
Next i
' Get the 'attr1' from child1.
Dim attr As XmlAttribute = doc.DocumentElement.ChildNodes(0).Attributes(0)
' Add this attribute to the attributecollection "ac".
ac.SetNamedItem(attr)
''attr1' will be removed from 'child1' and added to 'child2'.
' Print out the number of attributes and their names.
Console.WriteLine(("Number of Attributes: " + ac.Count))
For i = 0 To ac.Count - 1
Console.WriteLine((i + 1 + ". Attribute Name: '" + ac(i).Name + "' Attribute Value: '" + ac(i).Value + "'"))
Next i
' Create a new attribute and add to the collection.
Dim attr2 As XmlAttribute = doc.CreateAttribute("attr4")
attr2.Value = "val4"
ac.SetNamedItem(attr2)
' Print out the number of attributes and their names.
Console.WriteLine(("Number of Attributes: " + ac.Count))
For i = 0 To ac.Count - 1
Console.WriteLine((i + 1 + ". Attribute Name: '" + ac(i).Name + "' Attribute Value: '" + ac(i).Value + "'"))
Next i
End Sub 'Main
End Class 'test
using System;
using System.Xml;
class test {
public static void Main() {
XmlDocument doc = new XmlDocument();
doc.LoadXml( "<root> <child1 attr1='val1' attr2='val2'> text1 </child1> <child2 attr3='val3'> text2 </child2> </root> " );
// Get the attributes of node "child2"
XmlAttributeCollection ac = doc.DocumentElement.ChildNodes[1].Attributes;
// Print out the number of attributes and their names.
Console.WriteLine( "Number of Attributes: "+ac.Count );
for( int i = 0; i < ac.Count; i++ )
Console.WriteLine( (i+1) + ". Attribute Name: '" +ac[i].Name+ "' Attribute Value: '"+ ac[i].Value +"'" );
// Get the 'attr1' from child1.
XmlAttribute attr = doc.DocumentElement.ChildNodes[0].Attributes[0];
// Add this attribute to the attributecollection "ac".
ac.SetNamedItem( attr );
// 'attr1' will be removed from 'child1' and added to 'child2'.
// Print out the number of attributes and their names.
Console.WriteLine( "Number of Attributes: "+ac.Count );
for( int i = 0; i < ac.Count; i++ )
Console.WriteLine( (i+1) + ". Attribute Name: '" +ac[i].Name+ "' Attribute Value: '"+ ac[i].Value +"'" );
// Create a new attribute and add to the collection.
XmlAttribute attr2 = doc.CreateAttribute( "attr4" );
attr2.Value = "val4";
ac.SetNamedItem( attr2 );
// Print out the number of attributes and their names.
Console.WriteLine( "Number of Attributes: "+ac.Count );
for( int i = 0; i < ac.Count; i++ )
Console.WriteLine( (i+1) + ". Attribute Name: '" +ac[i].Name+ "' Attribute Value: '"+ ac[i].Value +"'" );
}
}
Pokud chcete zobrazit další příklad kódu, který ukazuje atribut, který je odebrán z AttributeCollection, viz XmlNamedNodeMap.RemoveNamedItem – metoda. Další informace o metodách a vlastnostech naleznete v tématu XmlNamedNodeMap Members.