我使用的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);
但这只会返回一行。你能帮我回复一个以上的结果吗?如何以上面指定的格式获得结果?
答案 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});
**编辑2:抱歉,但我错过了他正在使用JSON.NET。使用JavaScriptSerializer
上面的代码会产生以下结果:
{"results":[{"id":1,"value":"ABC","info":"ABC"},{"id":2,"value":"XYZ","info":"XYZ"}]}