When a json result is returned by the controller the object name seems to be missing, I normally wouldn't mind but the flexbox jquery plugin requires the json result in a particular format.
Flexcombobox expected format
{"results":[  
     {"id":"1","name":"Ant"},  
     {"id":"2","name":"Bear"},  
     {"id":"3","name":"Cat"},  
     {"id":"4","name":"Dog"},  
     {"id":"5","name":"Elephant"},  
     {"id":"6","name":"Fox"},  
     {"id":"7","name":"Guinea Pig"},  
     {"id":"8","name":"Horse"},  
     {"id":"9","name":"Iguana"},  
     {"id":"10","name":"Jaguar"}  
 ]} 
Class
Public Class FlexboxResult
    Private _id As String
    Public Property Id() As String
        Get
            Return _id
        End Get
        Set(ByVal value As String)
            _id = value
        End Set
    End Property
    Private _name As String
    Public Property Name() As String
        Get
            Return _name
        End Get
        Set(ByVal value As String)
            _name = value
        End Set
    End Property
End Class
Controller Code
Function PartYearsList() As JsonResult
            Dim yearSelectList As List(Of FlexboxResult) = New List(Of FlexboxResult)
            For index As Integer = DateTime.Now.Year To 1955 Step -1
                yearSelectList.Add(New FlexboxResult() With {.Id = index, .Name = index})
            Next
            Return Me.Json(yearSelectList.ToArray(), JsonRequestBehavior.AllowGet)
End Function
Json result returned (shortened)
[{"Id":"2010","Name":"2010"},{"Id":"2009","Name":"2009"},{"Id":"2008","Name":"2008"}]
Desired result (shortened)
{"results": [{"Id":"2010","Name":"2010"},{"Id":"2009","Name":"2009"},{"Id":"2008","Name":"2008"}]}
Flexcombobox documentation http://www.fairwaytech.com/flexbox.aspx
In C#, you can use an anonymous object to tweak the JSON structure on its way out:
// The ToArray() probably isn't necessary. Collections like List<T> are treated
//  as JavaScript arrays when JavaScriptSerializer turns them into JSON.
return Json(new { results = yearSelectList});
Update:
From Dien, this is the VB syntax for the same thing:
Return Json(New With {Key .results = yearSelectList}, JsonRequestBehavior.AllowGet)
                        To get fine grain control of the output JSON, you could try declaring a data contract like:
[DataContract]
public class MyResultListContract
{
    [DataMember]
    public List<MyResultContract> results { get; set; }
}
[DataContract]
public class MyResultContract
{
    [DataMember]
    public string Id {get; set;}
    [DataMember]
    public string Name {get; set;}
}
and then using the DataContractJsonSerializer:
var myResults = ...
var serialiser = new DataContractJsonSerializer(typeof(MyResultListContract));
var jsonString = serialiser.WriteAsString(myResults);
                        If you love us? You can donate to us via Paypal or buy me a coffee so we can maintain and grow! Thank you!
Donate Us With