У меня есть страница, на которой мне нужно перезагрузить широты и долготы, чтобы обновить карту Google. Я делаю это, используя ajax, функция JS такая:
function refreshMap(idCamiones)
{
$.ajax({
type: "GET",
async: false,
url: "refresh.php",
data: "idCamiones="+idCamiones,
contentType: "application/x-www-form-urlencoded",
success : function(text)
{
refresh = text;
}
});
//Borramos todos los marcadores actuales
for (i in markersArray) {markersArray[i].setMap(null);}
markersArray.length=0;
//generamos un array con las latitudes en pares y las longitudes en nones.
posArray=refresh.split(",");
for(i=0;i<=posArray.length;i=i+2)
{
addMarker(2,posArray[i],posArray[i+1]);
}
}
refresh
- глобальная переменная JS, в которой хранится ответ из файла PHP. Если я вызываю файл PHP с помощью браузера, данные завершены, я получаю (posArrray[0],..,posArray[n])
, но если я вызываю PHP с помощью функции JS, переменная JS сохраняет только (posArray[n-1],posArray[n])
, а все остальные координаты отсутствуют только в переменная JS мой PHP-скрипт работает хорошо.
<?php
include_once("conexion.php");
$idCamiones=$_GET['idCamiones'];
$reponse='';
$query="SELECT * from datos INNER JOIN dbo.eventos ON eventos.codigo=datos.codigo where id IN (
Select max(id) from datos where camion in (".$idCamiones.") group by serie) order by serie";
$bD=new COM("ADODB.Recordset");
$bD->Open($query,$conn);
$busData=fetch_assoc($bD);
$bD->close();
for($i=0;$i<sizeof($busData);$i++)
{
$response.=$busData[$i]['latitud'].",".$busData[$i]['longitud'].",";
}
echo $response;
?>
Я не знаю, возвращаю ли я $ response в php-файле неправильно, я тоже пытался с refresh=$.ajax({}).responseText;
и получаю те же результаты.