chcę przekonwertować tablicę obiektów do kodowania json, robię jak tenjson kodowanie nie jest praca z tablicą obiektów
$allVisits = $mapper->getAllVisits($year, $month);
echo json_encode($allVisits);
i oto jest metoda getAllVisists
function getAllVisits($year, $month) {
$where = array(
'year = ?' => $year,
'month = ?' => $month
);
$resultSet = $this->getDbTable()->fetchAll($where);
$visitsEntries = array();
foreach ($resultSet as $row) {
$entry = new Visits_Model_Visit();
$entry->setId($row->visit_id)
->setDay($row->day)
->setDate($row->date)
->setTarget($row->target)
->setStatus($row->visit_status)
->setTime($row->visit_time);
$visitsEntries[] = $entry;
}
return $visitsEntries;
}
kiedy echo wielkość $ allVisits zwróci poprawną liczbę rekordów, ale w js wartości odbierane są puste jak ta [{} {} {} {}]
Edit
Kiedy print_r ($ allVisists) brfore kodującego go zwraca
Array
(
[0] => Visits_Model_Visit Object
(
[day:private] => sunday
[date:private] => 2012-03-06
[target:private] => شسي
[id:private] => 1
[status:private] => 0
[time:private] => 12:00:00
)
[1] => Visits_Model_Visit Object
(
[day:private] => sunday
[date:private] => 2012-03-06
[target:private] => clinnics
[id:private] => 4
[status:private] => 0
[time:private] => 00:00:00
)
[2] => Visits_Model_Visit Object
(
[day:private] => Tuesday
[date:private] => 2012-03-06
[target:private] => clinnics
[id:private] => 5
[status:private] => 0
[time:private] => 00:00:00
)
[3] => Visits_Model_Visit Object
(
[day:private] => Wednesday
[date:private] => 2012-03-28
[target:private] => ??????? ???????
[id:private] => 7
[status:private] => 0
[time:private] => 12:00:00
)
)
Czy próbowałeś 'print_r ($ allVisits)' przed wywołaniem 'json_encode'? – jerrymouse
Drukuje poprawnie tablicę – palAlaa