2013-10-23 8 views
5

私は、JavaScriptからjsonフィードを使用してPHPスクリプトを通してデータベースから情報を送信する必要があるプロジェクトがあります。ここではスクリプトは、次のとおりです。PHP jsonフィードを作成し、それをjavascriptに正常にリンクする

これはjavascriptのである:

<link rel= 'stylesheet' type='text/css' href='fullcalendar/fullcalendar/fullcalendar.css' /> 
<link rel="stylesheet" media="print" href="fullcalendar/fullcalendar/fullcalendar.print.css" /> 
<script type="text/javascript" src="fullcalendar/lib/jquery.min.js"></script> 
<script type='text/javascript' src="fullcalendar/fullcalendar/fullcalendar.js"></script> 
<script type="text/javascript" src="fullcalendar/lib/jquery-ui.custom.min.js" ></script> 
<script> 
$(document).ready(function() { 
    $('#calendar').fullCalendar({ 
     header: { 

       left: 'prev,next today', 

       center: 'title', 

       right: 'month,basicWeek,basicDay' 

      }, 
      editable: true, 

      events: "public_calendar.php" 
    }) 
}); 
</script> 
</head> 

<body> 

    <div id='calendar'></div> 
</body> 
</html> 



?php require_once("includes/initialize.php"); ?> 
<?php require_once(LIB_PATH.DS.'database.php'); ?> 

<?php 
    //Find all the events 
    $events = Event::find_all(); 
     foreach($events as $event): 

      $id = (int) $event->id; 
      $title = "{$event->event_title}"; 
      $start = "{$event->start_date}" ." ". "{$event->start_time}"; 
      $end = "{$event->end_date}" ." ". "{$event->end_time}"; 
      $url = "event_detail.php"; 

      echo json_encode(array(
       'id' => $id, 
       'title' => "{$title}", 
       'start' => "{$start}", 
       'end' => "{$end}", 
       'url' => "{$url}" 
      ));   
     endforeach; 

?> 

これはPHPスクリプトがどのように見えるべきかされています

[ {"id":111,"title":"Event1","start":"2013-10-10","url":"http:\/\/yahoo.com\/"}, 
    {"id":222,"title":"Event2","start":"2013-10-20","end":"2013-10-22","url":"http:\/\/yahoo.com\/"} 
] 

これは、今どのように見えるかです:

{"id":12,"title":"Matriculation","start":"2013-11-5 08:00","end":"2013-11-5 17:00","url":"event_detail.php"} 
{"id":13,"title":"Exam","start":"2013-11-30 09:00","end":"2013-11-30 16:00","url":"event_detail.php"} 
{"id":2,"title":"Convocation","start":"2013-12-11 08:00","end":"2013-12-11 19:00","url":"event_detail.php"} 

ご協力いただきありがとうございます。

+1

各アレイをjsonストリングとして出力しないでください。 ** main **配列内のすべての配列をプッシュし、その配列をjson_encodeします。 –

答えて

3

結果を得るには、PHPで配列を作成し、json_encode()を使用して出力を作成するのが最善の方法です。あなたは既にこののいくつかをやっている - あなただけもう少し必要があります。

<?php 
//Find all the events 
$events = Event::find_all(); 
$eventList = array();   // Assemble list of all events here 

    foreach($events as $event): 

     $eventList[] = array(    // Add our event as the next element in the event list 
      'id' => (int) $event->id, 
      'title' => $event->event_title, 
      'start' => $event->start_date." ".$event->start_time, 
      'end' => $event->end_date." ".$event->end_time, 
      'url' => "event_detail.php" 
     );   
    endforeach; 

    echo json_encode($eventList);  // encode and output the whole list. 
?> 

私も簡略化し、不必要な二重引用符を削除するには、コードの一部を短縮しました。