douyu4822 2011-12-26 19:02
浏览 54
已采纳

尝试使用JQuery从PHP JSON多维数组中获取数据的问题

I have a multidimensional array which, when echoed in PHP, looks like this:

{
    "11-12-20":{"visits":0,"pageviews":0}
    "11-12-21":{"visits":0,"pageviews":0}
    "11-12-22":{"visits":0,"pageviews":0}
}// etc.

As you can see, the date is the key to the arrays inside the multidimensional array. So I can select an array from the multidimensional array using the date as the key:

$my_multi_array['12-12-12'];

JSON:

$.getJSON('file.php', function(data){
    var test='11-12-29';
    document.write(data.test);
});

When I test that in a browser, nothing is printed on the screen. Also, how would I go about looping through the whole of that array in jQuery and use the data inside that array's array.

I've been at this for hours now, and am pretty frustrated.

  • 写回答

2条回答 默认 最新

  • douqin6785 2011-12-26 19:31
    关注

    The PHP output that you have echoed is not an array, it's a JSON object without comma separators, which means it's not correctly formed.

    If you correct the syntax, you can access the objects in data through the index notation ([]), not the dot operator (.). So instead of accessing data like data.test, you should try data[test].

    Assuming you name your JSON object myJson, here's how you can iterate thought it:

    var myJson = {
        "11-12-20":{"visits":0,"pageviews":0},
        "11-12-21":{"visits":0,"pageviews":0},
        "11-12-22":{"visits":0,"pageviews":0}
    }
    
    for (var item in myJson)
    {
        alert(myJson[item].visits + ", " + myJson[item].pageviews);
    }
    
    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论
查看更多回答(1条)

报告相同问题?

悬赏问题

  • ¥15 宇视监控服务器无法登录
  • ¥15 PADS Logic 原理图
  • ¥15 PADS Logic 图标
  • ¥15 电脑和power bi环境都是英文如何将日期层次结构转换成英文
  • ¥20 气象站点数据求取中~
  • ¥15 如何获取APP内弹出的网址链接
  • ¥15 wifi 图标不见了 不知道怎么办 上不了网 变成小地球了
  • ¥50 STM32单片机传感器读取错误
  • ¥50 power BI 从Mysql服务器导入数据,但连接进去后显示表无数据
  • ¥15 (关键词-阻抗匹配,HFSS,RFID标签天线)