谷歌地图API的place_changed事件未触发

4

我在ASP.NET MVC项目中使用了Google Maps API v3。
我想向用户展示一张地图,用户可以在上面搜索某个地方并选择,然后提交(非常简单)。在这种情况下,除了在地图搜索框中输入时获取建议的位置之外,一切都很顺利。
以下是我如何包含Google Maps API:

<script src="https://maps.googleapis.com/maps/api/js?key=Correct_Key_Dot_Worry&libraries=places&callback=initMap" async defer></script>

html

<body>
    <input id="pac-input" class="controls" type="text" placeholder="Search Box">
    <input type="button" value="hakam" id="btntest" />
    <div id="map" style="width:500px; height:500px; margin-top:400px"></div>
</body>

javascript

 window.initMap = function(){
     var map = new google.maps.Map(document.getElementById('map'), {
         center: { lat: -33.8688, lng: 151.2195 },
         zoom: 13
     });
     var input = (document.getElementById('pac-input'));

     map.controls[google.maps.ControlPosition.TOP_LEFT].push(input);

     var autocomplete = new google.maps.places.Autocomplete(input);
     autocomplete.bindTo('bounds', map);

     var infowindow = new google.maps.InfoWindow();
     var marker = new google.maps.Marker({
         map: map,
         anchorPoint: new google.maps.Point(0, -29)
     });

     google.maps.event.addListener(autocomplete, 'place_changed', function () {
         infowindow.close();
         marker.setVisible(false);
         var place = autocomplete.getPlace();
         if (!place.geometry) {
             window.alert("Autocomplete's returned place contains no geometry");
             return;
         }

         // If the place has a geometry, then present it on a map.
         if (place.geometry.viewport) {
             map.fitBounds(place.geometry.viewport);
         } else {
             map.setCenter(place.geometry.location);
             map.setZoom(17);  // Why 17? Because it looks good.
         }
         marker.setIcon(({
             url: place.icon,
             size: new google.maps.Size(71, 71),
             origin: new google.maps.Point(0, 0),
             anchor: new google.maps.Point(17, 34),
             scaledSize: new google.maps.Size(35, 35)
         }));
         marker.setPosition(place.geometry.location);
         marker.setVisible(true);


         var address = '';
         if (place.address_components) {
             address = [
               (place.address_components[0] && place.address_components[0].short_name || ''),
               (place.address_components[1] && place.address_components[1].short_name || ''),
               (place.address_components[2] && place.address_components[2].short_name || '')
             ].join(' ');
         }

         //infowindow.setContent('<div><strong>' + place.name + '</strong><br>' + address);
         infowindow.setContent('<div><strong>' + "Location(" + place.geometry.location.lat() + "," + place.geometry.location.lng() + ")" + '</strong><br>');
         infowindow.open(map, marker);
     });

 }

问题

当我在谷歌地图搜索框中开始输入时,place_changed的处理程序不会触发,处理程序的代码也不会被调用。

经过大约6小时的搜索和思考,我阅读了谷歌地图API关于此事件的文档,如下所示:

当用户选择一个地点时,将为该地点提供PlaceResult时,将触发此事件。 如果用户输入了一个未被控件建议的地方名称并按Enter键,或者如果Place详细信息请求失败,则将触发place_changed事件,其中包含name属性中的用户输入,没有其他属性定义。

正如文档所说,当我点击'enter'键时,我确实会触发这个事件place_changed,并且再次,正如文档所说,我得到了包含用户输入的响应。

问题 为什么a PlaceResult is NOT made available for a Place the user has selected。(根据谷歌文档) 我做错了什么,让谷歌阻止我使用这个事件?

注意1
请不要向我推荐有关此主题的StackOverflow问题,因为我已经从早上开始(超过6小时)逐个阅读了所有问题,但没有任何帮助。

注意2
JavaScript示例已从谷歌地图API文档中获取。

注意3
如下所示,在加载谷歌地图库时设置语言和区域:

<script src="https://maps.googleapis.com/maps/api/js?key=mykey&&language=ar&region=EG&libraries=places&callback=initMap" async defer></script>

未解决我的问题。

@Titus,你有在你的机器上尝试过并且成功了吗?请告诉我这个非常重要。 - Hakan Fıstık
不清楚在哪种情况下 place_changed 回调函数不会运行(您是否期望在输入时调用它?) - Dr.Molle
事件在您输入时不会触发。 - Dr.Molle
好的,没问题,我只是想要自动完成,那么我的代码有什么问题呢? - Hakan Fıstık
您在开发者控制台中启用了“Google Places API”服务吗? - Dr.Molle
显示剩余8条评论
1个回答

2
这个问题已经在评论中得到了回答并且我将对此进行概括。
所有上面的内容(在问题中)都是正确的,没有任何错误。我只需要从Google开发者控制台启用Google Places API

这里有一个类似的SO问题: Google Map Autocomplete API not adding address options

顺便说一下:当您在搜索框中输入时,place_changed事件不必触发,这是我的想法。


即使启用了地点 API,它对我仍然无效。有没有人可以帮帮我? - theFrontEndDev

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