我创造的几个Gmarkers(从java载的JQuery"载荷"的功能),所有他们,我添加一个事件的听众开放的信息窗口对象我之前创建关于标记,然后我加入他们所有的地图。

问题是,信息窗口始终打开了在同一标记。我的所有了这个工作之前,我不能看看那里的问题是...范围的变量?愚蠢的错误的地方吗?

我上传一个 , 和这里是一个 快捷方式javascript文件

代码:

    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);
            };

        });
    });
有帮助吗?

解决方案

改变

infowindow.open(map,marker);

infowindow.open(map,this);
许可以下: CC-BY-SA归因
不隶属于 StackOverflow
scroll top