11

Creo diversi Gmarker (dai dati JSON caricati dalla funzione "load" di JQuery), su tutti aggiungo un listener di eventi per aprire l'oggetto infowindow che ho creato prima sull'indicatore, e poi li aggiungo tutti alla mappa.Google map (v3) apertura in apertura sullo stesso marcatore tutto il tempo

Il problema è che la finestra di apertura si apre sempre sullo stesso indicatore. Ho funzionato tutti prima, non riesco a vedere dove si trova il problema ... portata della variabile? stupido errore da qualche parte?

ho caricato un example, ed ecco un shortcut to the javascript file

Il codice:

var map; 
    var infowindow; 
    $(document).ready(function() { 

     var myLatlng = new google.maps.LatLng(47.15984,2.329102); 
     var myOptions = { 
     zoom: 6, 
     center: myLatlng, 
     mapTypeId: google.maps.MapTypeId.HYBRID, 
     scrollwheel: false 
     } 

     map = new google.maps.Map(document.getElementById("map_canvas"), myOptions); 

     infowindow = new google.maps.InfoWindow({content:'<p>Test</p>'}); 

     $.getJSON("data.json", function(data) { 

      var markers = []; 
      for (var i = data.length - 1; i >= 0; i--){ 
       var latLng = new google.maps.LatLng(data[i].lat, data[i].lng); 
       var marker = new google.maps.Marker({position: latLng}); 

       google.maps.event.addListener(marker, 'click', function() { 
        infowindow.open(map,marker); 
       }); 

       markers.push(marker); 
      }; 

      for (var j = markers.length - 1; j >= 0; j--){ 
       markers[j].setMap(map); 
      }; 

     }); 
    }); 

risposta

25

Change

infowindow.open(map,marker); 

a

infowindow.open(map,this); 
+7

Questo ragazzo è impressionante :) – Julien

Problemi correlati