谷歌地点API - 地点详细信息请求未定义

9
我正在尝试使用Google Places库检索地点详细信息。当您单击地点标记时,我希望能够看到地址、名称、网站等信息。
我正在使用以下教程:http://code.google.com/apis/maps/documentation/javascript/places.html 一切似乎都很顺利。在我的标记中,我可以显示名称和评级,但地址、网站和电话号码都显示为“未定义”。这是因为Google没有我请求这些地点的信息吗?还是我做错了什么?
这是我正在使用的代码:var map; var infowindow;
  function initialize() {
    var pyrmont = new google.maps.LatLng(-33.8665433, 151.1956316);

    map = new google.maps.Map(document.getElementById('map_canvas'), {
      mapTypeId: google.maps.MapTypeId.ROADMAP,
      center: pyrmont,
      zoom: 15
    });

    var request = {
      location: pyrmont,
      radius: 5000,
      types: ['bar']
    };
    infowindow = new google.maps.InfoWindow();
    service = new google.maps.places.PlacesService(map);
    service.search(request, callback);
  }

  function callback(results, status) {
    if (status == google.maps.places.PlacesServiceStatus.OK) {
      for (var i = 0; i < results.length; i++) {
        createMarker(results[i]);
      }
    }
  }

  function createMarker(place) {
    var placeLoc = place.geometry.location;
    var marker = new google.maps.Marker({
      map: map,
      position: place.geometry.location
    });

    google.maps.event.addListener(marker, 'click', function() {
      infowindow.setContent(place.name + "<br />" + place.formatted_address +"<br />" + place.website + "<br />" + place.rating + "<br />" + place.formatted_phone_number);
      infowindow.open(map, this);
    });
  }

任何帮助或想法都将不胜感激。
干杯。
JA
2个回答

21

您正在进行地点搜索,该搜索不会返回您使用的所有字段:

http://code.google.com/apis/maps/documentation/javascript/places.html#place_search_responses

为了获取地址、网站等信息,您还需要调用place.getDetails(),并传递地点的reference。参见:

http://code.google.com/apis/maps/documentation/javascript/places.html#place_details_requests

大致上,你的代码会变成这样:
  function createMarker(place) {
    var placeLoc = place.geometry.location;
    var marker = new google.maps.Marker({
      map: map,
      position: place.geometry.location
    });

    var request = { reference: place.reference };
    service.getDetails(request, function(details, status) {
      google.maps.event.addListener(marker, 'click', function() {
        infowindow.setContent(details.name + "<br />" + details.formatted_address +"<br />" + details.website + "<br />" + details.rating + "<br />" + details.formatted_phone_number);
        infowindow.open(map, this);
      });
    });
  }

没问题!很高兴能帮忙 :) - Mike Jeffrey
嗨,我遇到了同样的问题并尝试了这个解决方案。但是无法得到结果。“service.getDetails(request,function(details,status))”在哪里声明这个服务变量?我需要在创建标记函数中重新声明吗? - Thakur
嗨,Thakur。service 变量在 initialize() 函数中被定义为全局变量。请参考原始问题的代码:service = new google.maps.places.PlacesService(map); - Mike Jeffrey
这是我的问题链接 https://stackoverflow.com/questions/47547932/google-places-api-location-marker-pop-up-showing-at-wrong-place ,我尝试了相同的代码,但无法获取地点、纬度等信息,而且标记弹出窗口没有显示在它们自己的位置上。它显示所有标记在最后添加的标记上。 - Thakur

0
根据Mike上面的回答,我建议将调用移动到监听器中,如下所示。这样,在渲染大量标记的情况下,只有在用户单击标记时才会调用API,而不是数百次。
function createMarker(place) {
    var placeLoc = place.geometry.location;
    var marker = new google.maps.Marker({
      map: map,
      position: place.geometry.location
    });

    var request = { reference: place.reference };

    google.maps.event.addListener(marker, 'click', function() {
      service.getDetails(request, function(details, status) {
      infowindow.setContent(details.name + "<br />" + details.formatted_address +"<br />" + details.website + "<br />" + details.rating + "<br />" + details.formatted_phone_number);
      infowindow.open(map, this);
    });
});

}


网页内容由stack overflow 提供, 点击上面的
可以查看英文原文,
原文链接