如何返回JSon对象

时间:2013-05-08 13:22:50

标签: c# json json.net

我使用的jQuery插件需要一个具有以下结构的JSON对象(我将从数据库中检索值):

{ results: [
    { id: "1", value: "ABC", info: "ABC" },
    { id: "2", value: "JKL", info: "JKL" },
    { id: "3", value: "XYZ", info: "XYZ" }
] }

这是我的班级:

public class results
{
    int _id;
    string _value;
    string _info;

    public int id
    {
        get
        {
            return _id;
        }
        set
        {
            _id = value;
        }
    }
    public string value
    {
        get
        {
            return _value;
        }
        set
        {
            _value = value;
        }
    }
    public string info
    {
        get
        {
            return _info;
        }
        set
        {
            _info = value;
        }
    }
}

这是我序列化它的方式:

results result = new results();
result.id = 1;
result.value = "ABC";
result.info = "ABC";
string json = JsonConvert.SerializeObject(result);

但这只会返回一行。你能帮我回复一个以上的结果吗?如何以上面指定的格式获得结果?

2 个答案:

答案 0 :(得分:28)

首先,有no such thing as a JSON object。您在问题中得到的是一个JavaScript对象文字(有关差异的详细讨论,请参阅here)。以下是您将如何序列化JSON的内容:

我会使用填充了results类型的匿名类型:

string json = JsonConvert.SerializeObject(new
{
    results = new List<Result>()
    {
        new Result { id = 1, value = "ABC", info = "ABC" },
        new Result { id = 2, value = "JKL", info = "JKL" }
    }
});

另请注意,生成的JSON包含id类型为Number的结果项,而不是字符串。我怀疑这会是一个问题,但在C#中将id的类型更改为string会很容易。

我还会调整你的results类型并删除支持字段:

public class Result
{
    public int id { get ;set; }
    public string value { get; set; }
    public string info { get; set; }
}

此外,课程通常为PascalCased而非camelCased

以下是上面代码中生成的JSON:

{
  "results": [
    {
      "id": 1,
      "value": "ABC",
      "info": "ABC"
    },
    {
      "id": 2,
      "value": "JKL",
      "info": "JKL"
    }
  ]
}

答案 1 :(得分:5)

您只有一行要序列化。尝试这样的事情:

List<results> resultRows = new List<results>

resultRows.Add(new results{id = 1, value="ABC", info="ABC"});
resultRows.Add(new results{id = 2, value="XYZ", info="XYZ"});

string json = JavaScriptSerializer.Serialize(new { results = resultRows});
  • 编辑以匹配OP的原始json输出

**编辑2:抱歉,但我错过了他正在使用JSON.NET。使用JavaScriptSerializer上面的代码会产生以下结果:

{"results":[{"id":1,"value":"ABC","info":"ABC"},{"id":2,"value":"XYZ","info":"XYZ"}]}