【问题标题】:Why my output in JSON data contain extra curly braces为什么我在 JSON 数据中的输出包含额外的花括号
【发布时间】:2017-02-12 19:19:07
【问题描述】:

这段代码的主要问题是它提供了额外的花括号..

<?php   
header('Content-Type: json');
include('config.php');

    for($i=1990;$i<=2016;$i++){
        $sum=0;
        $data1=array();
        $result=mysql_query("select * from crimedetails  where crime_year=$i");
        while($row=mysql_fetch_array($result))
          {
            $sum+=$row['crime_mudered'];
            $data['crime_mudered']=$sum;
            $data['crime_year']=$row['crime_year'];
            }
          $data3[]=$data;
    }           
    array_push($data1,$data3);
    print json_encode($data1);
?>

输出数据:

【问题讨论】:

  • 你得到的正是你所要求的。另一个数组 ($data1) 内的数组 ($data3) 内的一堆查询结果行 ($data)。
  • 不使用array_push ..它工作正常..谢谢

标签: php mysql json


【解决方案1】:

只需使用 array_merge() 而不是 array_push()

【讨论】:

  • 当我使用 array_merge() 时只使用 array_merge() 而不是 array_push() 它会隐藏所有数据
【解决方案2】:

当您将json_encode() 应用于关联数组时,方括号变为大括号。那是因为它正在将该数组编码为 JavaScript Object Notation (JSON)。因此,在 JavaScript 中,关联数组是具有属性的对象。而且,要在 JavaScript 中定义具有属性的对象,您可以使用 花括号 ({})。

【讨论】:

    猜你喜欢
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 2019-09-18
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    相关资源
    最近更新 更多