Json.Net: Mitglieder einer von List
Json.Net behandelt Klassen, die IEnumerable implementieren, standardmäßig als Arrays. Um dieses Verhalten zu überschreiben, markieren Sie die abgeleitete Klasse mit den Attributen [JsonObject] und [JsonProperty]. Dadurch werden jedoch nur die Mitglieder der abgeleiteten Klasse serialisiert, nicht die Liste.
Um sowohl die Mitglieder der abgeleiteten Klasse als auch die Liste zu serialisieren, stellen Sie eine öffentliche Eigenschaft für die abgeleitete Klasse bereit, um die Liste verfügbar zu machen:
class PagedResult<T> : List<T> { public IEnumerable<T> Items { get { return this; } } }
Alternativ erstellen Sie einen benutzerdefinierten JsonConverter, um das Ganze zu serialisieren:
class PagedResultConverter<T> : JsonConverter { public override bool CanConvert(Type objectType) { return (objectType == typeof(PagedResult<T>)); } public override void WriteJson(JsonWriter writer, object value, JsonSerializer serializer) { PagedResult<T> result = (PagedResult<T>)value; JObject jo = new JObject(); jo.Add("Properties", JObject.FromObject(result, serializer)); jo.Add("Items", JArray.FromObject(result.ToArray(), serializer)); jo.WriteTo(writer); } public override object ReadJson(JsonReader reader, Type objectType, object existingValue, JsonSerializer serializer) { JObject jo = JObject.Load(reader); PagedResult<T> result = new PagedResult<T>(); jo["Properties"].ToObject<PagedResult<T>>(serializer); result.AddRange(jo["Items"].ToObject<T[]>(serializer)); return result; } }
Registrieren Sie den Konverter im JsonSerializerSettings:
JsonSerializerSettings settings = new JsonSerializerSettings(); settings.Converters.Add(new PagedResultConverter<T>());
Das obige ist der detaillierte Inhalt vonWie serialisiere ich eine von einer Liste in Json.Net abgeleitete Klasse und behalte dabei sowohl benutzerdefinierte Eigenschaften als auch Listenelemente bei?. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!