非常感谢您的帮助。
我在一个返回json序列化字符串List<Dictionary<string,int>>
的操作中有以下代码,但我正在努力使用JQuery将数据转换为视图中的可用格式。我希望能够遍历每个字典。
我在使用List之前已经这样做了,所以我可以设想创建一个新模型,但我相信我应该能够反序列化它。
如果有人可以建议一种方法来反序列化这些数据或者首先发送数据的更好方法,我将不胜感激。
MenuController:
public JsonResult Populate(string id) {
// Get and process data, creating all, a List<Dictionary<string,int>>
JavaScriptSerializer serializer = new JavaScriptSerializer();
string json = serializer.Serialize((object)all);
return Json(json, JsonRequestBehavior.AllowGet);
}
我也尝试了以下方法,而不是使用JavascriptSerielizer,但结果相同:
return Json(JsonConvert.SerializeObject(all), JsonRequestBehavior.AllowGet);
cshtml jquery:
<script type="text/javascript">
$.get('@Url.Action("Populate","Menu")', { id: "MO" }, function (data) {
console.log(data);
var obj = jQuery.parseJSON(data);
console.log('obj: ' + obj);
for (var o in obj) {
console.log('o is: ' + o);
}
})
.done(function (d) {
console.log('done: ' + d);
})
.fail(function (d) {
console.log('fail: ' + d);
});
</script>
在控制台中我得到:
数据
[{"foo":2,"bar":0,"ray":3,"doh":1},{"mee":1,"so":0,"lah":2,"far":0}]
OBJ
obj: [object Object],[object Object]
0
o is: 0
o is: 1
完成
done: [{"foo":2,"bar":0,"ray":3,"doh":1},{"mee":1,"so":0,"lah":2,"far":0}]
非常感谢你的帮助。
答案 0 :(得分:0)
因此列表被转换为数组和字典到对象,所以似乎一切正常。在Javascript中,您已经传递了一个包含两个对象的数组。您可以按如下方式迭代每个对象(这是翻译的字典):
var data;// your downloaded JSON object
for(var i = 0;i < data.length; ++i) //for enumerating array
{
var obj = data[i];
for(var propName in obj) //for enumerating the properties of an object
{
var value = obj[propName];
alert("item : " + i + " : prop : " + propName + " : value : " + value);
}
}