如何使用多行/结果解析JSON

时间:2015-06-24 06:39:15

标签: javascript jquery ajax json

我不知道这是否是格式错误的JSON字符串,但我无法弄清楚如何解析每个结果以获取数据。

这是来自我的$ .ajax函数的data.d响应(它在Code Behind(C#)中调用WebMethod):

{"Row":[
{"ID1":"TBU9THLCZS","Project":"1","ID2":"Y5468ASV73","URL":"http://blah1.com","Wave":"w1","StartDate":"18/06/2015 5:46:41 AM","EndDate":"18/06/2015 5:47:24 AM","Status":"1","Check":"0"},
{"ID1":"TBU9THLCZS","Project":"2","ID2":"T7J6SHZCH","URL":"http://blah2.com","Wave":"w1","StartDate":"23/06/2015 4:35:22 AM","EndDate":"","Status":"","Check":""}
]}

通过我看过的所有示例,只有一两个显示了我的'Row',并且解决方案没有关联,例如一个人在最后一个数组之后有逗号。

如果不是直接的回答,我会很满意。

我尝试过各种各样的response.Row,response [0]组合,使用$ .each,但我无法得到它。

编辑,这是我的ajax电话:

$.ajax({
    url: "Mgr.aspx/ShowActivity",
    type: "POST",
    data: JSON.stringify({
        "ID": "null"
    }),
    contentType: "application/json; charset=utf-8",
    dataType: "json",
    success: function (response) {
        var data = response.hasOwnProperty("d") ? response.d : response;
        console.log(data);
    },
    error: function (xhr, ajaxOptions, thrownError) {
        $('#lblResErr').html('<span style="color:red;">' + thrownError);
    }
});

目前我一直试图将ID1值和ID2值输入控制台。

编辑(已解决):感谢YTAM和Panagiotis!

success: function (response) {
    var data = response.hasOwnProperty("d") ? response.d : response;
    data = JSON.parse(data);
    console.log(data);
}

现在控制台向我展示了两个对象的数组,现在我知道如何处理它们了!!

2 个答案:

答案 0 :(得分:1)

您可能从Web方法获取json字符串而不是实际的JavaScript对象。通过将其解析为JavaScript对象 做

var data = JSON.parse(response); 

然后您就可以迭代data.Row

答案 1 :(得分:1)

首先,您必须使用JSON.parse

解析字符串

var data = JSON.parse (rowData);

然后你会得到如下所示的对象,

data = {
"Row": [
{
  "ID1":"TBU9THLCZS",
  "Project":"1",
  "ID2":"Y5468ASV73",
  "URL":"http://blah1.com",
  "Wave":"w1",
  "StartDate":"18/06/2015 5:46:41 AM",
  "EndDate":"18/06/2015 5:47:24 AM",
  "Status":"1",
  "Check":"0"
},
{
  "ID1":"TBU9THLCZS",
  "Project":"2",
  "ID2":"T7J6SHZCH",
  "URL":"http://blah2.com",
  "Wave":"w1",
  "StartDate":"23/06/2015 4:35:22 AM",
  "EndDate":"",
  "Status":"",
  "Check":""
}
]}

这里我给出了两个选项,可以直接从数据变量中检索数据,也可以通过循环。

data.row[0].ID1
data.row[0].Project
data.row[0].ID2

等等

使用循环,

var result = json.row;
for (var i = 0; i < result.length; i++) {
  var object = result[i];
   for (property in object) {
    var value = object[property];
  }
}

希望这有帮助。