所以我试图简单地修饰一个类以将其序列化为 XML。这是我的问题的一个例子。
[XmlElement("Dest")]
public XmlNode NewValue { get; set; }
这里真正的问题是有时在此实现中 XmlNode 可以是 XmlElement 或 XmlAttribute。当它是一个元素时,这段代码工作正常,但是当它作为一个属性出现时,序列化程序会抛出以下错误:
System.InvalidOperationException:无法将 XmlAttribute 类型的节点写入元素值。使用带有 XmlNode 或 XmlAttribute 数组的 XmlAnyAttributeAttribute 将节点写为属性。
我尝试了 XmlAnyAttribute,但也失败了。简单地说,我如何序列化 XmlNode?p>
为了记录,我在下面标记了正确答案。你有点得破解它。以下是我自己实现的大致内容,以防其他人遇到此问题。
[XmlIgnore()]
public XmlNode OldValue { get; set; }
[XmlElement("Dest")]
public XmlNode SerializedValue
{
get
{
if (OldValue == null)
{
return null;
}
if (OldValue.NodeType == XmlNodeType.Attribute)
{
XmlDocumentFragment frag = OldValue.OwnerDocument.CreateDocumentFragment();
XmlElement elem = (frag.OwnerDocument.CreateNode(XmlNodeType.Element, "SerializedAttribute", frag.NamespaceURI) as XmlElement);
elem.SetAttribute(OldValue.Name, OldValue.Value);
return elem;
}
else
{
return OldValue;
}
}
set
{
if (value == null)
{
OldValue = null;
return;
}
if ((value.Attributes != null) && (value.NodeType == XmlNodeType.Element) && ((value.ChildNodes == null) || (value.ChildNodes.Count == 0)))
{
OldValue = value.Attributes[0];
}
else
{
OldValue = value;
}
}
}
最佳答案
你可以尝试破解它(我同意它不是很好):
XmlNode v;
[XmlElement("Dest")]
public XmlNode NewValue { get{return v as XmlElement;} set{v = value;} }
[XmlAttribute("Dest")]
public NewValue { get{return v as XmlAttribute;} set{v = value;} }
关于c# - .NET 序列化 XmlNode 问题,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/2020912/