me quedé atrapado con OOP PHP y datos json. No soy completamente nuevo en OOP, pero no puedo entender esto. si alguien puede por favor explicarme, sería genial!Pasar datos de la clase PHP a PHPExcel a través de AJAX
tengo el siguiente objeto de cuadrícula en PHP:
Class Grid {
var $data;
var $joins;
var $fields;
var $where;
var $table;
var $groupBy;
var $having;
var $limit;
var $order_by;
var $sort;
var $security;
var $set;
var $sql;
....
// loads data into the grid
function load() {
...
// setup the sql - bring it all together
$sql = "
SELECT $post[cols]
FROM `$table`
$joins
$where
$groupBy
$having
ORDER BY $order_by $sort
$limit
";
$this->sql = $sql;
// execute the sql, get back a multi dimensial array
$rows = $this->_queryMulti($sql);
// form an array of the data to send back
$data = array();
$data['rows'] = array();
foreach($rows as $i=>$row) {
foreach($row as $col=>$cell) {
// use primary key if possible, other wise use index
$key = $primaryKey ? $row[$primaryKey] : $i;
// primary key has an _ infront becuase of google chrome re ordering JSON objects
//http://code.google.com/p/v8/issues/detail?id=164
$data['rows']["_".$key][$col] = $cell;
}
}
...
$data['order_by'] = $order_by;
$data['sort'] = $sort;
$data['page'] = $page;
$data['start'] = $startRow + 1;
$data['end'] = $startRow + $nRowsShowing;
$data['colData'] = $colData;
$this->data = $data;
}
y se llama AJAX callgrid.php:
$grid->load();
// here we need to add field in data[sql] = sql query, then we can pass it to toExcel() - how?
echo json_encode($grid->data);
lo que estoy tratando de conseguir es ser capaz de exportar actual consulta sql (puede ser todos o resultados buscados) en Excel usando PHPExcel. Así que tengo queExcel.php con la función toexcel ($ query) - que tomará una consulta y lo exportará a Excel.
ahora - ¿CÓMO paso la consulta sql de la cuadrícula a toexcel a través de AJAX?
entiendo que tengo que añadir a los datos ($):
datos$ [ 'sql'] = $ sql;
¿qué sigue?
ACTUALIZACIÓN: estoy usando la siguiente cuadrícula de jQuery: http://square-bracket.com/openjs
entiendo que PHPExcel debe iniciarse ya sea por cuadrícula o jQuery
Por qué a través de AJAX? ¿Por qué no hacerlo todo dentro de PHP? – Mchl
porque la red se carga desde ajax. por lo que la consulta sql se formará solo cuando sea invocada por ajax: '$ (". grid.digital_edit "). loadGrid ({...})' – Elen
ok - no necesito estar atascado con AJAX. pero ¿cómo, de todos modos? – Elen