这是一个数组,对象还是仅一个看起来像Json并从PHP输出的字符串?

问题描述

| 好吧,我在读取由PHP输出的jQuery中的JSON数据时遇到问题, 我在用
json_encode();
<?PHP
require_once \'Post_db.PHP\'; // a Class for doing MysqL work

/* the Post class */    
class Post {

/* An array that stores the post item data: */

private $pdata;

/* The constructor */
public function __construct($postData){
if(is_array($postData))
$this->pdata= $postData;
}



public function __toString(){
// The string that is beeing returned
// is outputed by the echo statement

$toBeJsoned=$this->pdata;
$toBeSent=json_encode($toBeJsoned);
return  $toBeSent;  
}

//read the Posts
public static function readPosts(){
$query = new Post_db(\"SELECT * FROM pmessage
                 ORDER BY p_id DESC
                 \");
$posts = array();
while($row = $query->fetchRow()){
$posts [] = new Post($row);
}
foreach($posts as $item){

echo $item;
}
}
现在,jQuery: 这段代码正在读取,但这只是
$.get
方法。并且它以带有约5000个elmenets的1个数组的形式返回
myPosts
,但是只有大约50个Posts,因此它将字符串中的每个字符作为数组元素。
function readMyPosts(){
        $.get(\"PHPFileThatCalltheFunctionsToRead.PHP\",{\"action\": \"autoRead\"},function(myPosts){        
            //a ul element
            $(\"#plist\").html(\"<li>\"+myPosts+\"</li>\");       

               });
                 }
    readMyFacts();
当我尝试使用
$.ajax
$.getJSON
时,我从未达到成功功能,实际上什么也没发生
  function ReadNewestFacts(){
        $.ajax({
        url:\"PHPFileThatCalltheFunctionsToRead.PHP\",data:\"action=autoRead_main\",dataType:\"json\",success: function(json){
            //do something with the data 
            alert(json);


            }});
      }
   //run this function
        ReadNewestFacts();
PHPFileThatCalltheFunctionsToRead.PHP
文件如下所示:
<?PHP

session_start();
require_once \"post.class.PHP\";


 if(isset($thisUid)){
$thisUid= $_GET[\'thisUid\'];
}

if(isset($action)){
$action = $_GET[\'action\'];
}

try{
    switch($_GET[\'action\'])
    {
        case \'autoRead_main\':
            Post::readPosts();
            break;      

        case \'autoRead\':
            Post::readMyPosts($_GET[\'thisUid\']);
            break;
            case \' more cases
               ..
                  .
                .
              .\'




    }

}
catch(Exception $e){
    // echo $e->getMessage();
    die(\"0\");
}
我只能恢复的是
{\"p_id\":\"1\",\"p_text\":\"blabla\",\"p_adder\":\"1\"}{\"p_id\":\"2\",\"p_text\":\"blabla2\",\"p_adder\":\"1\"}{\"p_id\":\"3\",\"p_text\":\"more blabla\",\"p_adder\":\"2\"}{\"p_id\":\"4\",\"p_text\":\"more and more blabla\",\"p_adder\":\"1\"}{}....
JSON格式似乎工作正常!!,但是我认为Jquery无法从PHP读取JSON字符串?我真的不确定在这里:( .. 我不愿意在jQuery端访问JSON数据。.我尝试了在StacKover上找到的许多方法..但我认为我缺少一些..     

解决方法

        您的问题是您要一起输出多个JSON对象。 这是因为PHP代码中的每个“ 11”对象都输出一个JSON块。您正在创建一个由
Post
对象组成的数组,因此您将获得多个JSON块。 您生成的每个JSON块都是有效的,但仅将它们串联在一起就不是有效的JSON。 如果要使
Post
对象输出其JSON对象的数组,则还需要为此编写JSON代码。 您不能对整个内容进行ѭ14编码,因为它已经被编码了,所以在代码中修复它的简便方法只是在输出的两端打印ѭ15或
]
,并在每个
Post
对象输出之间打印一个逗号。 。 您可以这样做:
echo \'[\'.implode(\',\',$posts).\']\';
而不是您的
foreach()
循环。     ,        您在\“ {} \”块之间缺少逗号
[{\"p_id\":\"1\",\"p_text\":\"blabla\",\"p_adder\":\"1\"},{\"p_id\":\"2\",\"p_text\":\"blabla2\",{\"p_id\":\"3\",\"p_text\":\"more blabla\",\"p_adder\":\"2\"},{\"p_id\":\"4\",\"p_text\":\"more and more blabla\",{}]
    ,        为了响应@JochenJung,您需要像这样:
json_encode( array( array1,array2,...) );
插入逗号。     ,        使用
json_encode()
json_decode()
    ,        尝试做
error: function(json){
            console.log(json);//need to have firebug


            }});
1.从所有文件中删除所有空白区域。(需要清理) 2.使用json_encode(\'HERE CAN ARRAY);