1

У меня есть конечная точка api, которая возвращает массив адресов и некоторую информацию о ценах для адресов, но не возвращает lat/lang, поэтому я использую геокод, чтобы показать маркер для адресов на карте и отображения infowindow при каждом нажатии маркера. Теперь я хочу, чтобы содержимое infowindow являлось ценой для адреса, который находится в массиве, возвращаемом с конечной точки. надеюсь, пока это ясно. Теперь проблема каждый раз, когда я нажимаю маркер, infowindow показывает только последнюю (такую ​​же) цену из массива на каждом инфундре, но не цену, связанную с этим адресом. см. мой код ниже (или зарегистрируйтесь в fiddlejs =>https://jsfiddle.net/puLxak1k/7/). Это может быть я пытаюсь вызвать синхронизацию в ASYN обратного вызова, поэтому я попытался с помощью $ q.promise и разрешения на первоначальный вызов апи и пытался дозвониться geocode.geocoder внутри .Затем, но не повезло еще ..Отображение содержимого из массива внутри infowindow на отметке маркера

<div id="map-canvas"></div> 
    function initialize() { 
    var chicago = new google.maps.LatLng(41.850033, -87.6500523); 
    var mapOptions = { 
     zoom: 7, 
     mapTypeId: google.maps.MapTypeId.ROADMAP, 
     center: chicago 
    } 
    map = new google.maps.Map(document.getElementById('map-canvas'), mapOptions); 
    geocoder = new google.maps.Geocoder() 
    var someArray = [{price: 10, address: 'cv64ad'}, {price: 20, address: 'cv59bp'}] 
    for (var i = 0; i < someArray.length; i++) { 
     var home = someArray[i] 
     console.log(home.address) 

     geocoder.geocode({'address': home.address}, function (results, status) { 
     if (status == google.maps.GeocoderStatus.OK) { 
      map.setCenter(results[0].geometry.location); 
      map.setZoom(12); 
      for (var i in results) { 
      var marker = new google.maps.Marker({ 
       position: new google.maps.LatLng(results[i].geometry.location.A, results[i].geometry.location.F), 
       map: map 
      }) 
      google.maps.event.addListener(marker, 'click', someCallback(home)) 
      infowindow = new google.maps.InfoWindow(); 
      function someCallback(home) { 
       return function (e) { 
       if (infowindow != null) { 
        infowindow.close(); 
       } 
       infowindow.setContent('<div class="infoheading">' + home.price + '</div>'); 
       infowindow.open(map, this); 
       } 
      } 
      } 
     } 
     }) 
    } 
    } 

    google.maps.event.addDomListener(window, 'load', initialize); 

ответ

3

Например: https://jsfiddle.net/jvxppeap/2/

Уловка: создать массив, содержащий объекты маркера. Затем, внутри addListener (маркер, 'click' ... вы проверяете, какой из маркеров был нажат, посмотрите на «indexOf» в моем коде. С помощью этого индекса вы можете прочитать правильный элемент someArray, и вы может добавить любую информацию, которую вы хотите там.

var markers = []; 
var map; 
var infowindow; 
function initialize() { 
    var chicago = new google.maps.LatLng(41.850033, -87.6500523); 
    var mapOptions = { 
    zoom: 7, 
    mapTypeId: google.maps.MapTypeId.ROADMAP, 
    center: chicago 
    } 
    map = new google.maps.Map(document.getElementById('map-canvas'), mapOptions); 
    geocoder = new google.maps.Geocoder(); 
    var someArray = [{price: 10, address: 'cv64ad'}, {price: 20, address: 'cv59bp'}]; 

    for (var i = 0; i < someArray.length; i++) { 
    var home = someArray[i]; 
    console.log(home.address); 

    geocoder.geocode({'address': home.address}, function (results, status) { 
     if (status == google.maps.GeocoderStatus.OK) { 
     map.setCenter(results[0].geometry.location); 
     map.setZoom(12); 
     for (var i in results) { 
      var marker = new google.maps.Marker({ 
      position: new google.maps.LatLng(results[i].geometry.location.A, results[i].geometry.location.F), 
      map: map 
      }); 
      // push the marker on the markers array 
      markers.push(marker); 
      google.maps.event.addListener(marker, 'click', function (home) { 
       if (infowindow != null) { 
       infowindow.close(); 
       } 
       // now, we want to know which of the markers we're talking about 
       var index = markers.indexOf(this); 
       infowindow.setContent('<div class="infoheading">' + someArray[index].price + '</div>'); 
       infowindow.open(map, this); 
      }); 
      infowindow = new google.maps.InfoWindow(); 
     } 
     } 
    }) 
    } 
} 
google.maps.event.addDomListener(window, 'load', initialize); 
+0

Спасибо Эммануила, это помогло и решить .... я был более склоняюсь к http://stackoverflow.com/questions/17684153/angular-js-pass-data -from-async-service-to-scope –

+0

Это сработало отлично. Спасибо, что положили полный код и объяснили функции в комментариях – user3411192