2009-09-19 17 views
5

JavaScriptSerializer serializuje typy wyprowadzone z IEnumerable jako tablice JavaScript. Jest to wygodne w przypadku tablic i list, ale w niektórych przypadkach konieczne jest przekształcenie do postaci szeregowej właściwości zadeklarowanych w typie pochodnym (np. Klucz w IGrouping). Oto przykładowy kod:JSON: Typy szeregowania wyprowadzone z IEnumerable

var items = new[] { "aaabbb", "abcd", "bdsasd", "bsdqw" }; 
IGrouping<char, string> data = items.GroupBy(i => i[0]).First(); 
var serializer = new JavaScriptSerializer(); 
var serialized = serializer.Serialize(data); 
// serialized == "[\"aaabbb\",\"abcd\"]" 
// doesn't contain definition for IGrouping.Key property 

Czy istnieje jakieś proste rozwiązanie tego problemu?

Odpowiedz

3

Można spróbować to:

var items = new[] { "aaabbb", "abcd", "bdsasd", "bsdqw" }; 
var data = (from x in items 
      group x by x[0] into g 
      select new 
      { 
       Key = g.Key, 
       Value = g 
      }).First(); 
var serializer = new JavaScriptSerializer(); 
var serialized = serializer.Serialize(data); 

lub jeśli wolisz:

var items = new[] { "aaabbb", "abcd", "bdsasd", "bsdqw" }; 
var data = items.GroupBy(i => i[0]) 
    .Select(x => new { Key = x.Key, Value = x }) 
    .First(); 
var serializer = new JavaScriptSerializer(); 
var serialized = serializer.Serialize(data); 

W obu przypadkach wynik będzie:

{"Key":"a","Value":["aaabbb","abcd"]} 
+0

Mam swój pomysł, ale szukam wspólnego rozwiązania z obsługą wszystkich typów pochodnych od IEnumerable: kolekcji ICollection, IGrouping, iLookup a nawet niestandardowe typy użytkowników – altso

2

Check out JSON.NET. Używałem go w kilku projektach, co znacznie ułatwia serializację i deserializację JSON. Będzie serializować większość obiektów za pomocą pojedynczego wywołania metody, a także pozwala uzyskać precyzyjniejszą kontrolę nad serializacją przy użyciu atrybutów niestandardowych.

Oto przykład ze strony internetowej autora:

Product product = new Product(); 

product.Name = "Apple"; 

product.Expiry = new DateTime(2008, 12, 28); 

product.Price = 3.99M; 

product.Sizes = new string[] { "Small", "Medium", "Large" }; 

string json = JsonConvert.SerializeObject(product); 

//{ 

// "Name": "Apple", 

// "Expiry": new Date(1230422400000), 

// "Price": 3.99, 

// "Sizes": [ 

// "Small", 

// "Medium", 

// "Large" 

// ] 

//} 



Product deserializedProduct = JsonConvert.DeserializeObject<Product>(json); 
+3

Fajnie! A co z niezliczoną liczbą "produktów"? To przewraca się z błędami .. – Aaron

+0

Mam ten sam problem. Niektóre niestandardowe typy implementujące IEnumerable niekoniecznie mają kolekcje zabezpieczające. Mogą być generowane dynamicznie, na przykład za pomocą "yield" lub LINQ. W takim przypadku chcę pominąć domyślną serializację tablic JavaScript i po prostu zapisać pozostałych członków klasy. –

+0

zadał moje pytanie tutaj: http://stackoverflow.com/questions/15034912/how-do-i-skip-default-javascript-array-serialization-for-ienumerable-types-in-js –

Powiązane problemy