如Newtonsoft在本期中所述,
metadataTypeAttributeJson.NET实际上支持属性。但是,
metadataClassType当相应的“真实”成员是属性时,似乎Json.NET要求成员必须是属性,而当相应的“真实”成员是字段时,则要求字段是域。因此,如果我
Plant按以下方式定义您的类型,并且具有两个属性和一个要序列化的字段:
public sealed partial class Plant : IEukaryote{ public System.Collections.Generic.IEnumerable<ICell> Cells { get { return (_valuesDict["Cells"] as System.Collections.IEnumerable).Cast<ICell>(); } } public string GenericName { get { return _valuesDict["GenericName"] as string; } } public string FieldIWantSerialized; public int SomethingIDonotWantSerialized { get { return 99999; } } // Remainder as before.然后,
Plantmetadata必须还必须具有两个属性和一个字段才能成功序列化它们:
//metadata.cs[System.ComponentModel.DataAnnotations.metadataType(typeof(Plantmetadata))]public sealed partial class Plant{ [JsonObject(MemberSerialization.OptIn)] internal sealed class Plantmetadata { [JsonProperty] public IEnumerable<ICell> Cells { get; set; } [JsonProperty] public string GenericName { get; set; } [JsonProperty] public string FieldIWantSerialized; }}如果我创建
Cells或
GenericName成为字段,或者
FieldIWantSerialized成为属性,则它们不会选择序列化。
示例工作 .Net Fiddle。
请注意,此外,我发现这些
metadataClassType属性显然必须具有与真实属性相同的 返回类型
。如果我将您的更改
Plantmetadata如下:
[JsonObject(MemberSerialization.OptIn)]internal sealed class Plantmetadata{ [JsonProperty] public object Cells { get; set; } [JsonProperty] public object GenericName { get; set; } [JsonProperty] public object FieldIWantSerialized;}然后仅
FieldIWantSerialized序列化,不对属性进行序列化。
.Net小提琴#2显示此行为。这可能是Newtonsoft的问题;如Microsoft文档在元数据类中定义属性中所述:
这些属性的实际类型并不重要,编译器将忽略它们。公认的方法是将它们全部声明为Object类型。
如果有问题,您可以向Newtonsoft
报告有关返回类型限制的问题-
或报告一个问题,要求对其支持的详细信息
metadataTypeAttribute进行更详细的记录。



