0

我有以下ajax调用:

$(document).ready(function() {
            $.ajax({
                type: "POST",
                url: "/LoadCount.aspx/GetCounts",
                contentType: "application/json; charset=utf-8",
                data: "",
                async: false,
                dataType: "json",
                success: function(data) {
                  var myObj = JSON.parse(data.d);
                  alert(myObj.length);
                  for (var i = 0; i < myObj.length; i++) {
                    alert(myObj[0]);
                  }

                },
                error: function(xhr, status, error) {
                    var err = eval("(" + xhr.responseText + ")");
                    alert(err.Message);
                }
            });
        });

当我提醒长度时,我变得不确定

这是我的 LoadCount.aspx 中的方法

[WebMethod]
    public static string ObtenerContador()
{
    List<MenuItem> menu =(List<MenuItem>)HttpContext.Current.Session["MenuItems"];

    Dictionary<string, int> dic = new Dictionary<string, int>();
    foreach (MenuItemAMostrar item in menu)
    { 
        dic.Add(item.ControlID,1);
    };

    return new JavaScriptSerializer().Serialize(dic); //or any other suggested serialization method
}

这就是我在成功功能中得到的:

{"MenuCLESAAsignar":1,"MenuOCGestores":1,"MenuOcAAutorizar":1,"MenuOcAAutorizarBanco":1,"MenuOCGestoresObservadas":1,"MenuCLESActivos":1,"MenuParametros":1,"MenuCLESConAddendaAAprobarSup":1,"MenuPendienteAprobacion":1,"MenuConsultaCLES":1}

问题是,如何在我的 ajax 成功函数中反序列化该字典?一旦反序列化,我如何填充它,获取数据?

谢谢!

4

2 回答 2

1

你在找这个吗?

success: function (data)
{               
    var myObj = JSON.parse(data.d);
},
于 2013-11-13T17:49:54.630 回答
1

正如其他人提到的,您只是JSON.parse()用来解析数据。

从那里它只是创建一个对象,您可以使用..

像这样:

http://jsfiddle.net/SJGLF/1/

var myData = JSON.parse(jsonData);
for(var i in myData)
{
    console.log(i + " = " + myData[i]);
}
于 2013-11-13T18:30:03.783 回答