Google maps - Мульти маркеры из базы данных долготы и широты не отображаются на карте

1

У меня есть этот код, который берет детали из базы данных и помещает их в php-массив, который затем передается в javascript для создания карты Google:

<?php
$query='select name,longitude,latitude from maps';
$result=mysql_query($query) or die();
$num_rows=mysql_num_rows($result);
if($num_rows > 0){
for($i=0;$i<$num_rows;$i++){
$row=mysql_fetch_row($result);

$location[]= $row[0].', '.$row[2].', '.$row[1].','.($i+1);


}
//this creates the following array
array(4) { 
[0]=> string(44) "Travel agent Marko, 42.5624525, 27.5263493,1" 
[1]=> string(44) "Travel agent Marko, 42.5632957, 27.5267364,2" 
[2]=> string(54) "Travel agent 'Planet Travel', 42.5609811, 27.5263934,3" 
[3]=> string(56) "Travel agent 'Planet Travel' 2, 42.5642942, 27.5266121,4" 
}

?>
<script type="text/javascript">
var loc = <?php echo json_encode($location); ?>;
var locations = [
[loc]
];


var map = new google.maps.Map(document.getElementById('googlemap'), {
  zoom: 10,
  center: new google.maps.LatLng(42.5624525, 27.5263493),
  mapTypeId: google.maps.MapTypeId.ROADMAP
});

var infowindow = new google.maps.InfoWindow();

var marker, i;
alert(locations.length);

for (i = 0; i < locations.length; i++) { 
  marker = new google.maps.Marker({
    position: new google.maps.LatLng(locations[i][1], locations[i][2]),
    map: map
  });

  google.maps.event.addListener(marker, 'click', (function(marker, i) {
    return function() {
      infowindow.setContent(locations[i][0]);
      infowindow.open(map, marker);
    }
  })(marker, i));
}
</script>

<?php
}
?>

мой вопрос в том, почему маркеры не появляются на карте? Ошибка не возвращается, но маркеров тоже нет. Мне нужно переместить код javascript в php loop? если я предупреждаю location.length, я получил 1 как location.length. Почему js подсчитывает массив местоположений как 1 место? Заранее спасибо !

  • 0
    Просто на заметку. Ваш код был бы чище, если бы вы держали PHP и Javascript отдельно. Таким образом, ваш PHP может выводить необходимые данные в конечную точку в JSON, а ваш JS может затем извлечь их из этого URL.
Теги:
google-maps
google-maps-api-3

1 ответ

3
Лучший ответ

Измените это:

var loc = <?php echo json_encode($location); ?>;
var locations = [
    [loc]
];

к этому:

var locations = <?php echo json_encode($location); ?>;

И цикл должен быть:

for (i = 0; i < locations.length; i++) { 

    loc_array = locations[i].split(",");

    marker = new google.maps.Marker({
        position: new google.maps.LatLng(loc_array[1], loc_array[2]),
        map: map
    });

    google.maps.event.addListener(marker, 'click', (function(marker, i) {
        return function() {
            infowindow.setContent(loc_array[0]);
            infowindow.open(map, marker);
        }
    })(marker, i));
}
  • 0
    Чувак, ты спас мой день! Отличный ответ! Мой Я также прошу вас удалить: center: new google.maps.LatLng (42.5624525, 27.5263493), маркеры скрыты. Как я могу установить его в центр авто? Спасибо!
  • 0
    Если вы имеете в виду центрирование карты, чтобы увидеть все маркеры, проверьте пример в этом ответе: stackoverflow.com/a/15720047/3052648

Ещё вопросы

Сообщество Overcoder
Наверх
Меню