XmlSerializer.UnknownElement Evento

Definición

Se produce cuando XmlSerializer detecta un elemento XML de tipo desconocido durante la deserialización.

C#
public event System.Xml.Serialization.XmlElementEventHandler UnknownElement;

Tipo de evento

Ejemplos

En el ejemplo siguiente se deserializa una clase denominada Group a partir de un archivo denominado UnknownElements.xml. Cada vez que se encuentra un elemento en el archivo que no tiene ningún miembro correspondiente en la clase , se produce el UnknownElement evento . Para probar el ejemplo, pegue el código XML siguiente en un archivo denominado UnknownElements.xml.

<?xml version="1.0" encoding="utf-8"?>
<Group xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xmlns:xsd="http://www.w3.org/2001/XMLSchema">
  <GroupName>MyGroup</GroupName>
  <GroupSize>Large</GroupSize>
  <GroupNumber>444</GroupNumber>
  <GroupBase>West</GroupBase>
</Group>
C#
using System;
using System.IO;
using System.Xml.Serialization;
using System.Xml;
using System.Xml.Schema;

public class Group{
   public string GroupName;
}

public class Test{
   static void Main(){
      Test t = new Test();
      // Deserialize the file containing unknown elements.
      t.DeserializeObject("UnknownElements.xml");
   }
   private void Serializer_UnknownElement(object sender, XmlElementEventArgs e){
      Console.WriteLine("Unknown Element");
      Console.WriteLine("\t" + e.Element.Name + " " + e.Element.InnerXml);
      Console.WriteLine("\t LineNumber: " + e.LineNumber);
      Console.WriteLine("\t LinePosition: " + e.LinePosition);
      
      Group x  = (Group) e.ObjectBeingDeserialized;
      Console.WriteLine (x.GroupName);
      Console.WriteLine (sender.ToString());
   }
   private void DeserializeObject(string filename){
      XmlSerializer ser = new XmlSerializer(typeof(Group));
      // Add a delegate to handle unknown element events.
      ser.UnknownElement+=new XmlElementEventHandler(Serializer_UnknownElement);
      // A FileStream is needed to read the XML document.
     FileStream fs = new FileStream(filename, FileMode.Open);
     Group g = (Group) ser.Deserialize(fs);
     fs.Close();
    }
}

Comentarios

De forma predeterminada, después de llamar al Deserialize método , omite XmlSerializer los atributos XML de tipos desconocidos. Sin embargo, puede usar este evento para controlar estos tipos de nodo.

Nota

XmlAnyElementAttribute Si se aplica a un campo que devuelve una matriz de XmlElement objetos, todos los elementos desconocidos se recopilan en la matriz. En ese caso, el UnknownElement evento no se produce.

Se aplica a

Produto Versións
.NET Core 2.0, Core 2.1, Core 2.2, Core 3.0, Core 3.1, 5, 6, 7, 8, 9, 10
.NET Framework 1.1, 2.0, 3.0, 3.5, 4.0, 4.5, 4.5.1, 4.5.2, 4.6, 4.6.1, 4.6.2, 4.7, 4.7.1, 4.7.2, 4.8, 4.8.1
.NET Standard 2.0, 2.1

Consulte también