Zet output in json_encode?

In following PHP code in here //print_r($reunits); is output this: http://pastebin.com/RbqZ5kHV

but in here echo json_encode($reunits); is output as: http://pastebin.com/GFdHkg5Y

If use $reunits = array('reunits'=>$units_data); as: $reunits .=... i get this output in echo json_encode($reunits);: "ArrayArrayArray"

Hoe kan output zoals output worden geplaatst in //print_r ($ reunits); op output echo json_encode ($ reunits); ? Hoe kan het oplossen?

$reunits = "";
//$tourf_id   = $this->input->post('tour_name');
$tourf_id = '102';
//$query_r = $this->db->order_by('id','desc')->get_where('tour_foreign_residence', array('relation' => $tourf_id));
$query_r = array('77192276', '15190364', '15183965')
foreach($query_r->result() as $idx=>$val){
    $hotel_id = $val->hotel_id;
    $query = $this->db->get_where('tour_foreign_units', array('hotel_id' => $hotel_id));
        $units_data = array();
        foreach ($query->result() as $index=>$row) {
            $units_data[] = array(
                'name' => $row->name,
                'price' => $row->price,
                'extra' => $row->extra,
                'hotel_id' => $row->hotel_id
            );
        }
    $reunits =  array('reunits'=>$units_data);
    //print_r($reunits);
}
echo json_encode($reunits);

Deze uitvoer wordt door json_encode naar ajax-aanroep in jQuery verzonden.

0

2 antwoord

Als u arrays concateert met de tekenreeks aaneenschakelingoperator (. ) worden de arrays omgezet in een tekenreeks (dat is "Array" in PHP) en vervolgens samengevoegd.

Gebruik in plaats hiervan een array-operator :

$reunits+=...

welke unie twee arrays zal vormen. Als union niet is wat u zoekt, kunt u array_merge gebruiken.

Vergeet niet om de variabele bovenaan ook als lege array te initialiseren:

$reunits = array();
0
toegevoegd

Als ik begrijp wat u vraagt, in plaats van te proberen in de array toe te voegen met . = , zou u de notatie [] moeten gebruiken om aan de array toe te voegen:

//Initialize reunits as an array
$reunits = array();


foreach($query_r->result() as $idx=>$val){
    $hotel_id = $val->hotel_id;
    $query = $this->db->get_where('tour_foreign_units', array('hotel_id' => $hotel_id));
        $units_data = array();
        foreach ($query->result() as $index=>$row) {
            $units_data[] = array(
                'name' => $row->name,
                'price' => $row->price,
                'extra' => $row->extra,
                'hotel_id' => $row->hotel_id
            );
        }


   //Append the array $units_data onto $reunits
   //since $units_data is already an array
    $reunits[] = $units_data;
}

// Now the JSON output should look like you expect
echo json_encode($reunits);
0
toegevoegd