使用C#对象创建JSON

8
我将尝试创建以下JSON数据:
{
'chart.labels': ['Bob','Lucy','Gary','Hoolio'],
'chart.tooltips': ['Bob did well',
               'Lucy had her best result',
               'Gary - not so good',
               'Hoolio had a good start'
              ]
}

我正在使用C#,尝试创建一个对象以执行这个操作...类似于:

public class chart{
 public string[] chart.labels {get;set;}
 public string[] chart.tooltips {get;set;}
}

但是显然我不能拥有包含空格的属性。

我该如何做到这一点?

更新:

使用JamieC的答案,以下内容完美运行。

public virtual ActionResult CompanyStatus()
    {
        var labelList = new List<string>() { "Bob", "Lucy", "Gary", "Hoolio" };
        var tooltipsList = new List<string>() { "Bob did well", "Lucy had her best result", "Gary - not so good", "Hoolio had a good start" };

        var cData = new chartData()
        {
            Labels = labelList.ToArray(),
            Tooltips = tooltipsList.ToArray()
        };

        var serializer = new DataContractJsonSerializer(cData.GetType());
        String output;
        using (var ms = new MemoryStream())
        {
            serializer.WriteObject(ms, cData);
            output = Encoding.Default.GetString(ms.ToArray());
        } 

        return this.Content(output);
    }


    [DataContract]
    public class chartData
    {
        [DataMember(Name = "chart.labels")]
        public string[] Labels { get; set; }

        [DataMember(Name = "chart.tooltips")]
        public string[] Tooltips { get; set; }

    }
}

这将产生:

{"chart.labels":["Bob","Lucy","Gary","Hoolio"],"chart.tooltips":["Bob did well","Lucy had her best result","Gary - not so good","Hoolio had a good start"]}

1
你是不是指“包含句点(点)的属性”? - David Hoerster
3个回答

9
通常的做法是使用 DataContractJsonSerializer 将对象转换为 Json,并使用 DataMember 属性来注释要用于属性的名称:
[DataContract]
public class ChartModel{
 [DataMember(Name = "chart.labels")]
 public string[] Labels {get;set;}
 [DataMember(Name = "chart.tooltips")]
 public string[] Tooltips {get;set;}
}

我个人使用自己的ActionResult在MVC中封装序列化:

public class JsonDataContractResult : ActionResult
{
    public JsonDataContractResult(Object data)
    {
        this.Data = data;
    }

    protected JsonDataContractResult()
    {

    }

    public Object Data { get; private set; }

    public override void ExecuteResult(ControllerContext context)
    {
        Guard.ArgumentNotNull(context, "context");

        var serializer = new DataContractJsonSerializer(this.Data.GetType());
        String output; 
        using (var ms = new MemoryStream())
        {
            serializer.WriteObject(ms, this.Data);
            output = Encoding.Default.GetString(ms.ToArray());
        } 
        context.HttpContext.Response.ContentType = "application/json";
        context.HttpContext.Response.Write(output);
    }        
}

在基础控制器中编写一个帮助方法,然后从该方法返回结果:

public abstract class MyBaseController: Controller
{

    protected JsonDataContractResult JsonContract(Object data)
    {
        return new JsonDataContractResult(data);
    }

}

然后我的控制器变得非常简单:
public class SomeController: MyBaseController
{
    public ActionResult SomeAction()
    { 
        var model = new ChartModel()
                   { 
                       Labels = ..., 
                       Tooltips = ... 
                   };
        return JsonContract(model);
    }
}

谢谢JamieC - 简单的部分现在已经运作正常。接下来会加入你的方法 :) - Mad Eddie

2
您可以使用JSON.NET库,您可以从此处下载。
它具有以下功能:
属性名称定制化
这个问题将会帮助您: Json.Net: JsonSerializer-Attribute for custom naming 您还可以使用DataContractJsonSerializer,它提供了这个功能,但JavaScriptSerializer不提供。

1
绝对没错。非常棒的库。 - Halil Ibrahim

0
对于MVC项目,可以使用Newtonsoft.Json库。(其他项目需要手动包含此库)
因此,在模型中添加JsonProperty,如下所示...
public class ChartModel{
    [JsonProperty("chart.labels")]
    public string[] Labels {get;set;}
    [JsonProperty("chart.tooltips")]
    public string[] Tooltips {get;set;}
}

并使用 Newtonsoft.Json.JsonConvert.SerializeObject(object);Json.Encode(object) 将其转换为 JSON。


网页内容由stack overflow 提供, 点击上面的
可以查看英文原文,
原文链接