我重构了这样的代码:
public string CamelCASE { get; set; }
至:
public string CamelCase {get; set; }
只发现输入XML包含前一个外壳(让我们称之为喊叫骆驼).我无法控制XML文档的生成方式.我也不愿意收回我的改变.
我想将喧嚣的骆驼财产映射到一个轻声说话的地方.
我已经尝试过XmlElement和XmlMapping,但没有取得更大的成功.谷歌搜索给了我关于如何将东西映射到属性的命令,沿着this post行.但是,我只需要像< LoudCAMEL>这样的东西.要反序列化为属性公共字符串QuietCamel.
有没有顺利的方法呢?
编辑
using System.Collections.Generic; using System.Xml; public class Beep : SuperBeep { private readonly BeepType _a; public Beep() { _a = BeepType.someSome; } public Beep(BeepType input) { _a = input; } ~Beep() { } public override void dispose() { } public BeepType Aaa { get { return _a; } } [XmlElement("CamelCASE")] public bool CamelCase { get; set; } }
我可以看到红色,波浪形的亮点告诉我由于其保护级别,无法访问构造函数“XmlElement”.但是,当我编译时,我让IDE大声喊出’System.Xml.XmlElement’不是属性类.
坦率地说,我对使用属性的建议(这是针对.NET 2.0)感到有点困惑,因为我的印象是在版本3.5之前.NET不能使用属性.我错了吗?
解决方法
[XmlElement("CamelCASE")] public string CamelCase { get; set; }
应该是你需要的所有,如果你在xml中保留shouty名称.如果要在新的xml中使用更安静的名称,但允许旧名称仍然有效,则会变得更复杂.你可以使用:
public string CamelCase { get; set; } [XmlElement("CamelCASE"),browsable(false)] [Editorbrowsable(EditorbrowsableState.Never)] public string CamelCaseLegacy { get { return CamelCase; } set { CamelCase = value; } } [browsable(false),Editorbrowsable(EditorbrowsableState.Never)] public bool ShouldSerializeCamelCaseLegacy() { return false; }
序列化时,CamelCase属性将序列化为< CamelCase>,并且由于ShouldSerialize *方法,CamelCaseLegacy元素将被忽略.但是,在反序列化时,只要< CamelCASE>就会使用CamelCaseLegacy属性.看到了.然后,我们将此值映射回CamelCase属性.
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。